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PREFACE 


This manual provides general information, preparation for use, programming in- 
formation, principles of operation, and service information for the iSBC 544 In- 
telligent Communications Controller Board. Supplementary information is provid- 
ed in the following documents: 

• Intel MULTIBUS Interfacing, Application Note AP-28. 

• Intel MCS-85 User’s Manual, Order No. 9800366. 

• Intel 8080 Microcomputer Peripherals User’s Manual, Order No. 98-364. 

• Intel 8080/8085 Assembly Language Programming Manual, Order 98-301 . 
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CHAPTER 1 
GENERAL INFORMATION 


1-1. INTRODUCTION 

The iSBC 544 Intelligent Communications Controller 
is a member of a complete line of Intel iSBC 80 
system components. The iSBC 544 operates as an in- 
telligent slave on the system, providing an expansion 
of system serial communications capability, in- 
cluding four fully programmable synchronous and 
asynchronous serial I/O channels with RS232C buf- 
fering. As an intelligent slave, the iSBC 544 employs 
its own 8085A CPU to handle all on-board process- 
ing. Baud rates, data formats, and interrupt 
priorities are individually software selectable for each 
channel. The iSBC 544 also includes 10 lines of buf- 
fered parallel I/O interface which provides com- 
patibility with a Bell 801 Automatic Calling Unit. 

The iSBC 544 is a self-contained communications 
processor that incorporates an 8085 A CPU (for on 
board processing only), up to 16K bytes of dynamic 
RAM, 8K bytes of PROM, and the aforementioned 
I/O interface. The intelligent slave concept allows the 
iSBC 544 to unburden a system CPU by performing 
all communications related peripheral tasks without 
constant interruption of the CPU. This concept 
allows for maximum I/O throughput on the system, 
with a minimum amount of impact on the system 
bus. The iSBC 544 accepts commands from the 
master CPU, performs the necessary functions to 
complete the peripheral operation, interrupts the 
master CPU on completion and allows the transfer of 
data into or out of on-board memory. 


The iSBC 544 is also capable of operating as a single 
board communications computer. In this mode, it 
can control a number of iSBC 534 Communication 
Expansion boards or other memory and I/O expan- 
sion boards. A list of the bus limitations of the iSBC 
544 used in this mode can be found in Chapter 3. 


1-2. DESCRIPTION 

The iSBC 544 (figure 1-1) is designed to be plugged 
into a standard iSBC 604/614 Modular Backplane 
and Cardcage to interface directly with an Intel iSBC 
Single Board Computer or used with an Intel 
Microcomputer Development System. The iSBC 544 
provides four serial I/O ports, one parallel I/O port, 
seven programmable timers, and eight interrupt in- 
puts with programmable priority. Also provided is a 
dedicated on-board processor consisting of an 8085A 
CPU and memory. 


1-3. SERIAL I/O PORTS 

Each of the four serial I/O ports is fully RS232C plug 
compatible and is controlled and interfaced by an In- 
tel 8251A USART (Universal Synchronous/ Asyn- 
chronous Receiver /Transmitter) chip. Each USART 
is individually programmable for operation in most 
synchronous or asynchronous serial data transmis- 
sion formats (including IBM Bi-Sync). 



Figure 1-1 . iSBC 544 Intelligent Communications Controller Board 
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In the synchronous mode the following are program- 
mable: 

a. Character length, 

b. Sync character (or characters), and 

c. Parity. 

In the asynchronous mode the following are pro- 
grammable: 

a. Character length, 

b. Baud rate factor (clock divide ratios of 1, 16, or 
64), 

c. Number of Stop bits, and 

d. Parity. 

In both the synchronous and asynchronous modes, 
each serial I/O port features half- or full-duplex, 
double-buffered transmit and receive capability. In 
addition, USART error detection circuits can check 
for parity, overrun, and framing errors. The USART 
transmit and receive clock rates are separately deriv- 
ed from one of five independently programmable 
Baud rate/time generators. 


1-4. PARALLEL I/O PORT 

The parallel I/O port has 10 buffered I/O lines 
controlled by an Intel 8155 Programmable Interface 
(PPI) chip. The parallel I/O port is directly 
compatible with an Automatic Calling Unit (ACU) 
such as the Bell Model 801, or equivalent, and can 
also be used for auxiliary functions. All signals are 
RS232C compatible, and the interface cable signal 
assignments meet RS366 specifications. 

If the system application does not require an inter- 
face to an ACU, the parallel I/O port can be used for 
any general purpose or auxiliary parallel interface 
that is RS232C compatible. 


1-5. PROGRAMMABLE TIMERS 

One of the primary features of the iSBC 544 is flexi- 
ble clock programming. The iSBC 544 has two Intel 
8253 Programmable Interval Timer (PIT) chips that 
provide a total of six separate time/rate generators. 
All six are independently software-programmable, 
and can generate different Baud rate clock signals for 
each USART chip. 

Four of the timers (BDG0-BDG3) are used as Baud 
rate generators; the fifth timer can be used as an aux- 
iliary transmit or receive clock, and the sixth timer 
can be used to generate an interrupt. 

In addition to the timers on the 8253 PITs, the iSBC 
544 has a 14-bit timer located on the 8155 PPI which 
can be used for miscellaneous functions. 


1-6. INTERRUPT FUNCTIONS 

The iSBC 544 has the following interrupt sources: 

a. Eight serial I/O interrupts serviced by an 8259 
Programmable Interrupt Controller (PIC). 

b. Flag Interrupt 

c. Carrier Detect and Ring Indicator Interrupts 

d. Multibus interrupts 

e. Timer Interrupts 

The 8259 PIC has eight input interrupt request lines. 
The PIC treats each true input signal condition as an 
interrupt request. After resolving the interrupt priori- 
ty, the PIC issues a single interrupt request to the on- 
board 8085 A CPU. The interrupt priorities of the 
PIC chip are independently programmable under 
software control. The programmable interrupt 
priority modes are: 

a. Fully Nested Priority. Each interrupt request has 
a fixed priority: input 0 is highest, input 7 is 
lowest. 

b. Auto-Rotating Priority. Each interrupt request 
has equal priority. Each level, after receiving ser- 
vice, becomes the lowest priority level until the 
next interrupt occurs. 

c. Specific Priority. Software assigns lowest 
priority. Priority of all other levels is in 
numerical sequence based on lowest priority. 

The Flag Interrupt allows any bus master to interrupt 
the iSBC 544 by writing into the base address of 
RAM memory. The flag interrupt is cleared when the 
on-board processor reads the base address. This flag 
provides a unique interrupt to each iSBC 544 in the 
system. 

The Carrier Detect and Ring Indicator Interrupts 
allow the iSBC 544 to monitor the serial I/O ports 
and detect the loss of a carrier signal or the ringing of 
a telephone line respectively. These interrupts are 
detected by the on-board 8085 A CPU, and available 
for interrogation through the 8155 PPI. 

The iSBC 544 can generate an interrupt on the 
Multibus, and also receive an interrupt from the bus. 


1-7. 8085ACPU 

The 8085A CPU, which is the heart of the iSBC 544, 
performs on-board processing functions and 
generates the addresses and control signals required 
to access memory and I/O devices. The 8085A con- 
tains six 8-bit general purpose registers and an ac- 
cumulator, The six general purpose registers may be 
addressed individually or in pairs, providing both 
single and double precision operations. 
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The 8085A has 5 prioritized interrupt inputs (TRAP, 
RST 7.5, RST 6.5, RST 5.5, and INTR) which 
generate unique memory addresses for interrupt 
handling routines. All interrupt inputs with the ex- 
ception of TRAP may be masked via software. 


1-8. PROM CONFIGURATION 

The ROM/PROM on the iSBC 544 consists of either 
4K or 8K bjdies. Two sockets are provided for user in- 
stallation of the PROM chips. Jumpers are provided 
for accommodation of different types of chips (Intel 
2716, or 2732E PROMs and 2316, or 2332 ROMs). 
Address block (X)00-1FFF is reserved for PROM 
use only. 


1-9. RAM CONFIGURATION 

The iSBC 544 includes 16K of dynamic RAM im- 
plemented with eight Intel 2117 chips and an Intel 
8202 Dynamic RAM Controller. Dual-port control 
logic allows the RAM to be accessed by either the on- 
board 8085A, or by another bus master. The RAM 
decode logic allows for extended Multibus addressing 


of up to 20 address lines. This allows bus masters 
with 20-bit addressing capability to partition the 
iSBC 544 into 16K segments in a 1 -mega-byte address 
space. The on-board 8085A CPU, however, has only 
a 16-bit address capability, and limits the on-board 
RAM to a 64K address space. 

The iSBC 544 also has 256 bytes of static RAM 
located on the Intel 8155 PPL This memory is only 
accessible to the on-board 8085 A CPU. The address 
block for the static RAM is 7F00-7FFF. 


1-10. EQUIPMENTSUPPLIED 

The following are supplied with the iSBC 544 In- 
telligent Communications Controller: 

a. Schematic Drawing, dwg. no. 2001695 

b. Assembly Drawing, dwg. no. 1001693 

1-11. SPECIFICATIONS 

Specifications for the iSBC 544 Intelligent Com- 
munications Controller are provided in table 1-1 . 


Table 1-1. Specifications 


8085ACPU 


WORD SIZE 

Instruction: 

8, 16, or 24 bits 

Data: 

8 bits 

CYCLE TIME: 

1.45 fisec ± 0.1% for fastest executable instruction; i.e., four clock 
cycles. 

MEMORY CAPACITY 

On-Board ROM /PROM 

4Kor8Kof user installed ROM/PROM. 

On-Board RAM (Dynamic) 

16K of RAM. Integrity maintained during power failure with 
user-furnished batteries, (optional) 

On-Board RAM (Static) 

256 bytes of RAM: 

MEMORY ADDRESSING: 

On-Board ROM /PROM 

0000-1 FFF 

On-Board Static RAM 

7F00-7FFF 

On-Board RAM 

16K: 8000-BFFF 

On-Board RAM 

Jumpers allow board to act as slave memory for other bus masters. 16 

(System Access) 

or 20 bit addressing can be accommodated. Boundaries may be set on 
any 4K increment OOOOO-FFOOO, which is switch selectable. 4K, 8K, or 
16K can be made available to the bus by switch selection. 

CPU RAM ACCESS TIME: 

450 nsec min, and 1100 nsec + off-board command duration max. 
CPU has priority over bus master access, however CPU request can- 
not abort bus master access in progress. 
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Table 1-1 . Specifications (Cont’d.) 


MINIMUM WAIT STATE 
CONSIDERATIONS 


Type 

On-Board Request 

Off-Board Request 
(Master Mode) 

Normal 

Refresh 

Normal 

Refresh 

I/O Read /Write 

None 

N/A 

N/A 

N/A 

Memory Write (Dyn.) 

1 

2 

2 

3 

Memory Read (Dyn.) 

None 

1 

1 

2 

Memory Write (Stat.) 

None 

None 

N/A 

N/A 

Memory Read (Stat.) 

None 

None 

N/A 

N/A 

Note: Dyn.=Dynamic RAM 


Stat.=Static RAM or PROM 


INTERRUPTS: 


8085A CPU includes five interrupt inputs, each of which vectors the 
processor to the following memory location for entry point to service 
routine: 


Interrupt 

Input 

Vector 

Address 

Priority 

Type 

TRAP 

24 

1 

Non-Maskable 

RST7.5 

3C 

2 

Maskable 

RST6.5 

34 

3 

Maskable 

RST5.5 

2C 

4 

Maskable 

INTR 

Note 

5 

Maskable 


Note: INTR input provided by 8259 PIC. See table 3-27 for vec- 
tor addresses. 


SERIAL COMMUNICATIONS 


Synchronous: 


Asynchronous: 


Sample Baud Rate: 


5-, 6-, 7-, or 8-bit characters. Internal; 1 or 2 sync characters. 
Automatic sync insertion, parity and overrun error detection. 

5-, 6-, 7-, or 8-bit characters. Break character generation and detec- 
tion 1, IVa, or 2 stop bits. False start bit detection, parity, overrun 
and framing error detection. 

Baud Rate (Hz)^ 


Frequency' 

(kHz, Software Selectable) 

Synchronous 

Asynchronous 



-r16 

-i-64 

153.6 

— 

9600 

2400 

76.8 

— 

4800 

1200 

38.4 

38400 

2400 

600 

19.2 

19200 

1200 

300 

9.6 

9600 

600 

150 

4.8 

4800 

300 

75 

6.98 

6980 

— 

110 


INTERVAL TIMER AND BAUD RATE GENERATOR 

Input Frequency: 


1. Frequency selected by I/O writes of ap- 
propriate 16-bit frequency factor to 
counter/timer Register. 

2. Baud rates shown here are only a sample subset 
of possible software-programmable rates 
available. Any frequency from 18.75 Hz to 614.4 
kHz may be generated utilizing on-board crystal 
oscillator and 16-bit Programmable Interval 
Timer (used here as frequency divider). 


On board 1.2288 MHz .1% crystal; 0.814 microsecond period, nominal or 
1.8432 MHz±.1% crystal; 0.542 microsecond period, nominal. 
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Table 1-1. Specifications (Cont’d.) 


Output Frequencies: 
(at 1.2288 MHz) 


Single Timer 

Duai Timers 
(Two Timers Cascaded) 

Min 

Max 

Min 

Max 

1 .63 (isec 

53.3 msec 

3.26 Msec 

58.25 

minutes 

18.75 Hz 

614.4 kHz 

0.00029 Hz 

307.2 kHz 


INTERFACE COMPATIBILITY 

Serial I/O: 


Parallel I/O: 

System Bus: 

I/O ADDRESSING: 

COMPATIBLE CONNECTORS/CABLE: 
POWER REQUIREMENTS: 


Function 

Real-Time 

Interrupt 

Interval 

Rate 

Generator 

(Frequency) 


EIA Standard RS232C signals provided and supported: 

Carrier Detect Receive Data 

Clear to Send Ring Indicator 

Data Set Ready Secondary Receive Data* 

DataTerminal Ready Secondary Transmit Data* 

Request to Send Transmit Clock 

Receive Clock T ransmit Data 

DTE Transmit 

* Optional if parallel port not used as ACU. 

4 input lines and 6 output lines; all signals compatible with EIA 
Standard RS232C. Directly compatible with Bell Model 801 Automatic 
Calling Unit. 

Compatible with Intel iSBC 80 Multibus. 

All communication to parallel and serial I/O ports, timers, and the 
interrupt controller is via read and write commands from the on-board 
8085A CPU . Refer to table 3-2 for specific addresses. 

Refer to table 2-2 for compatible connector details. 



1 

2 

3 

4 

Vcc = +5V ± 5% 

Ice = 3.4 max. 

*CC ~ 3.3Amax. 

*CC “ 390mA max. 

Ice = 390mA max. 

Vdd = +12V ± 5% 

Iqd = 350mA max. 

Iqd = 350 max. 

*DD “ 176mA max. 

Iqq = 20mA max. 

VgB = -5V ± 5% 

Ig0 = Note 5 

Igg = Note 5 

IgB = 5mA max. 

Ibb “ 5mA max. 

< 

> 

> 

II 

< 

li- 

en 

l^y^ = 200mA max. 

l^y^ = 200mA max. 




Notes: 1 . 

Assuming two 2716 PROMs installed 

2. 

No PROMs installed 


3. 

For operational RAM only, for AUX power supply rating. 

4. 

For RAM refresh only. Used for battery backup requirements. No RAM accessed. 

5. 

VgB is normally derived on board from If Vgg supplied from bus, max requirement is 5mA. 

ENVIRONMENTAL REQUIREMENTS 


Operating Temperature: 

O'’to55* (32*to13rF). 

Relative Humidity: 

To 90% without condensation. 

PHYSICAL CHARACTERISTICS 


Width: 


30.48 cm (12.00 inches). 

Depth: 


17.15 cm (6.75 inches). 

Thickness: 


1.27 cm (0.50 inch). 

Weight: 


397 gm (14 ounces). 
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2-1. INTRODUCTION 

This chapter provides information for preparing the 
iSBC 544 Intelligent Communications Controller for 
use in the user-defined environment. This informa- 
tion includes unpacking and inspection; installation 
considerations; optional component installation; 
jumper configurations; multibus configuration; data 
set conversion; power fail/memory protect con- 
figuration; I/O cabling; and board installation. 

2-2. UNPACKING AND INSPECTION 

Inspect the shipping carton immediately upon receipt 
for evidence of mishandling during transit. If the 
shipping carton is severly damaged or waterstained, 
request that the carrier’s agent is present when the 
carton is opened. If the carriers agent is not present 
when the carton is opened, and the contents of the 
carton are damaged, keep the carton and packing 
material for the agent’s inspection. 

For repairs to a product damaged in shipment, con- 
tact the Intel Technical Support Center (see 
paragraph 5-4) to obtain a Return Authorization 
Number and further instructions. A purchase order 
will be required to complete the repair. A copy of the 
purchase order should be submitted to the carrier 
with your claim. 

It is suggested that salvageable shipping cartons and 
packing material be saved for future use in the event 
the product must be shipped. 


2-3. INSTALLATION 
CONSIDERATIONS 

The iSBC 544 Intelligent Communications Controller 
is designed for use as an ’’intellegent slave”. It can be 
used any time the user desires to maximize I/O 
throughput with a minimum amount of impact on 
the system bus. The iSBC 544 is able to do this, 
because of its architecture which consists of a 
dedicated on-board 8085A CPU, dedicated on-board 
memory, and a variety of peripheral chips which per- 
form such functions as format control, code conver- 
sions, data link control, error checking, and buffer 
management. 

Important criteria for installing and interfacing the 
iSBC 544 in the above environment is presented in 
the following paragraphs. 

2-4. USER FURNISHED COMPONENTS 

Because the iSBC 544 can be used in a variety of ap- 
plications, the user must purchase and install only 
those components which satisfy his particular needs. 
A list of components required to configure the iSBC 
544 can be found in table 2-1 . Table 2-2 is a list of the 
types and vendors of those connectors listed in table 
2 - 1 . 

2-5. POWER REQUIREMENTS 

The iSBC 544 requires +5V, +12V, and -12V power 
supply inputs. The currrents required from these sup- 
plies are listed in table 1-1 . 


Table 2-1 . User Furnished and Installed Components 


ITEM 

No. 

ITEM 

DESCRIPTION 

USE 

1 

iSBC 604 

Modular Backplane and Cardcage. 
Includes four slots with bus terminators. 

Provides power input pins and Multibus 
signal interface between iSBC 544 and 
three additional boards in a multiple 
board system 

2 

iSBC 614 

Modular Backplane and Cardcage. 
Includes four slots without bus ter- 
minators. 

Provides four-board extensions of iSBC 

604 

3 

Connector 
(mates with PI) 

See Multibus Connector details in table 

2-2. 

Power inputs and Multibus signal 
interface. Not required if iSBC 544 install- 
ed in an iSBC 604/614. 


2-1 






















Preparation For Use 


iSBC 544 


Table 2-1 . User Furnished and Installed Components (Cont’d.) 


ITEM 

No. 

ITEM 

i 

DESCRIPTION 

USE 

4 

Connector 
(mates with P2) 

See Auxiliary connector details in table 
2-2. 

Auxiliary backup battery inputs and 
associated memory protect functions 

5 

Connector 
(mates with J1, 

J2, J3, orJ4) 

See Serial I/O connector details in table 

2-2. 

Interfaces Serial I/O ports to Intel 8251A 
Programmable Communications Inter- 
face (USART) 

6 

Connector 
(mates with J5) 

See parallel I/O connector details in 
table 2-2 

Interface parrallel I/O port to Intel 8155 

7 

EPROM chips 

Intel 2716 (2Kx8) 

Intel 2732/2732A (4Kx8) 

On-board UV erasable EPROM for pro- 
gram development and/or dedicated 
program use. 

8 

Capacitors 

Four capacitors as required. 

Rise time/noise capacitors for serial 

I/O port. 

9 

Jumpers 

- 

To connect optional power to serial I/O 
connectors J1-J4. 

10 

DIP Header 
Jumper 

- 

To convert data terminal interface to data 

set interface 


Table 2-2. User Furnished Connector Details 


FUNCTION 

NO. OF 

PAIRS/ 

CENTERS 

CONNECTOR 

VENDOR 

VENDOR 

INTEL 


PINS 

(inches) 

TYPE 


PART NO. 

PART NO. 

Parallel/ 




3M 

3462-0001 


Serial 

13/26 

0.1 

Flat Crimp 

AMP 

88106-1 

iSBC955 

I/O 




ANSLY 

609-2615 

Cable 

Connector 

(J1-J5) 




SAE 

SD6726 Series 

Set 

Parallel/ 

Serial 

13/26 

0.1 

Soldered 

Tl 

H312113 

N/A 

I/O 

Connector 

(J1-J5) 




AMP 

1-583485-5 


Parallel/ 

Serial 

I/O 

Connector 

(J1-J5) 

13/26 

0.1 

Wire wrap^ 

Tl 

H311113 

N/A 

Multibus 




CDC3 

VPB01E43D00A1 


Connector 

43/86 

0.156 

Soldered’ 

MICRO PLASTICS 

MP-015fr43-BW-4 


(PI) 




ARCO 

i 

AE443WP1 

Less Ears 

N/A 





VIKING 

2VH43/1AV5 
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Table 2-2. User Furnished Connector Details (Cont’d.) 


FUNCTION 

NO. OF 

PAIRS/ 

PINS 

CENTERS 

(inches) 

CONNECTOR 

TYPE 

VENDOR 

VENDOR 

PART NO. 

INTEL 

PART NO. 

Multibus 




CDC3 

VFB01E43D00A1 


Connector 

43/86 

0.156 

Wire wrapi -2 

CDC3 

VPB01E43A00A1 

MDS 985 

(P1) 




VIKING 

2VH43/1AV5 


Auxiliary 







Connector 

30/60 

0.1 

Soldered’ 

Tl 

H312130 

N/A 

(P2) 




VIKING 

3VH30/1JN5 


Auxiliary 







Connector 

30/60 

0.1 

Wi rewrap '-2 

CDC3 

VPB011B30A00A2 

N/A 

(P2) 




Tl 

H311130 



NOTES: 

1 . Connector heights are not guaranteed to conform to OEM packaging equipment. 

2. Wire wrap pin lengths are not guaranteed to conform to OEM packaging equipment. 

3. CDC VPB01... VPB02... VPB04... etc. are identical connectors with different electroplating thicknesses or 
metal surfaces. 

4. Connector numbering convention may not agree with board connector numbers. 


2-6. COOLING REQUIREMENTS 

The iSBC 544 dissipates 275 gram-calories/minute 
(1.11 BTU/minute) and adequate circulation of air 
must be provided to prevent a temperature rise above 
55°C (131° F). The System 80 enclosures and the In- 
tellec System include fans to provide adequate intake 
and exhaust of ventilating air. 


2-7. PHYSICAL DIMENSIONS 

Physical dimensions of the iSBC 544 are as follows: 

a. Width: 30.48cm (12.00 inches) 

b. Height: 17.15cm (6.75 inches) 

c. Thickness: 1.25cm (0.50 inch) 


2-8. COMPONENT INSTALLATION 

Instructions for installing the optional EPROMS, 
jumpers, and rise time/noise capacitors are given in 
the following paragraphs. When installing the op- 
tional chips; be sure to orient pin 1 of the chip adja- 
cent to the white dot located near pin 1 of the 
associated IC socket. The grid location on figure 5-1 
(parts location diagram) and figure 5-2 (schematic 
diagram) are specified for each user installed com- 
ponet. Because the schematic diagram consists of 
nine sheets, grid references to figure 5-2 consist of 
four alphanumeric characters. For example reference 
5ZB3 signifies sheet 5, zone B3. 


2-9. EPROM CHIPS 

Install the EPROM chips in IC sockets A35 and A51 
(refer to figure 5-1 zone C2 and figure 5-2 zone 4ZD3). 
Sockets A51 and A35 respectively, accommodate the 
low-order and high-order addresses of the EPROM 
chip pair. For instance if two Intel 2716 EPROM’s 
are installed, the chip installed in IC socket A51 is 
assigned addresses 0000-07FF and the chip installed 
in IC socket A35 is assigned addresses 0800-0FFF. 
The default (factory connected) jumpers are con- 
figured for Intel 2716 EPROMs. If Intel 2732 EPROMs 
are used, A51 = OOOO-OFFF and A35 = 1000-lFFF. 


2-10 RISE TIME/NOISE CAPACITORS 

Eye pads are provided so that rise time/noise 
capacitors may be installed as required on the in- 
dividual serial I/O pins. The selection of capacitor 
values is at the option of the user and is normally a 
function of the particular environment. The location 
of these eye pads are as follows: 


Capacitor 

FIG 5-1 

FIG 5-2 

C5 

D7 

8ZD5 

C9 

D6 

8ZB6 

C13 

D5 

9ZD5 

C17 

D4 

9ZB6 
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2-11 JUMPER CONFIGURATIONS 

The iSBC 544 includes a variety of jumper-selectable 
options to allow the user to configure the board for 
his particular application. Table 2-3 summarizes 
these jumper selectable options and lists the grid 
reference locations of the jumpers as shown in figure 
5-1 (part location diagram) and figure 5-2 (schematic 
diagram). The grid references for figure 5-2 are four 
alphanumeric characters long to denote sheet number 
and zone. For example grid reference 5ZB3 denotes 
sheet 5 zone B3. 


Study table 2-3 carefully while making reference to 
figures 5-1 and 5-2. If the default (factory installed) 
jumper wiring is appropriate for a particular func- 
tion, no further action is required for that function. 
If, however, a different configuration is required, 
remove the default jumper(s) and install the optional 
jumper(s) as specified . For most options, the in- 
formation in table 2-3 is sufficient for proper con- 
figuration. Additional information, where necessary 
for clarity, is described in subsequent paragraphs. 


2-12. PROM CONFIGURATION 

Table 2*3 lists the jumper configurations for using 
2716 PROM or 2732/2732A PROM chips and 2316 or 
2332 ROM chips. 

2-13. ON-BOARD RAM 

The on-board 8085 A has access to 16K of RAM star- 
ting at location 8000H. The addresses would be: 

SIZE LOCATIONS 

16K 8000 - BFFF 

Another bus master can access 4K, 8K, or 16K of 
iSBC 544 on-board RAM via the Multibus. The base 
address of this system accessable RAM is jumper and 
switch selectable as shown in table 2-3. It should be 
noted, that if the base address coming on the 
Multibus does not match the switch selectable base 
address, no RAM access will be allowed. This selec- 
tion is performed by an Intel 3625-2 PROM located 
at A41 on the iSBC 544 


Table 2-3 Jumper Selectable Options 


FUNCTION 

Fig 5-1 
GRID REF 

Fig 5-2 
GRID REF 

DESCRIPTION 

PROM Configuration 

C3 

4ZC3 

The following jumpers accommodate one of two types of PROM chips. 

Intel 2716/231 6E - 38-39, 40-41 

Intel 2732 - 41-42 

Intel 2732A/2332 - 41-42, 45-46 

PROM Size 

C6 

4ZB6 

SWI Position 7 selects PROM size 




On (0) = 8K - See Appendix D. 

Off (1) = 4K 

On-Board RAM 



The following describes the selection of on-board RAM by another 

(System Access) 



system component. 


B6 

4ZA7 

*72-73, 74-75 - Selects lower 51 2K 




73-74 

-Selects upper 51 2K 


B6 

4ZA6 

51-52 

448-51 2K or 1 024-1 088K 




53-54 

384-448K or 960-1 024K 




55-56 

320-384K or 832- 896K 




57-58 

256-320K or 768- 832K Select 




59-60 

192-256K or 704- 768K 64K 




61-62 

128-192K or 640- 704K 




63-64 

64-1 28K or 576- 640K 




*65-66 

0- 64K or 512- 576K 





NOTE 





Jumper selectable only on a 20 bit system. 
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Table 2-3 Jumper Selectable Options Continued 


FUNCTION 


Fig 5-1 
GRID REF 


Fig 5-2 
GRID REF 


Auxiliary Backup 
Power 


On-Board -5V 
Regulator 


Timer Input 
Frequency 
(8253 PIT) 




SW1 - Positions 1-4 select base address of the 4K, 8K, 
or 16K of RAM that is accessible by the 
system. (0=ON, 1=OFF) 

For example: 

Switch Setting Base Address 

4321 


(4K or8K only) 


SW1- Positions 5-6 select RAM size as follows: 


Switch Setting 
6 5 


RAM Size 


If the base address you select does not allow for the RAM size 
you have selected, you will not be able to access RAM at all. 
This allows for the case where the iSBC 544 RAM is not used by 
the bus. 


Jumper 76-77 to route Bus Clock signal BCLK/ to the Multibus. Only if 
this iSBC 544 is acting as bus master. 


The Frequency does not meet Multibus specifications. 


Jumper 78-79 to route Constant Clock signal CCLK/ to the Multibus. 
Only If this iSBC 544 is acting as bus master. 


The frequency does not meet Multibus specifications. 


If auxiliary backup Power is employed to sustain memory during ac 
power outages, remove default jumpers *W12, *W13, and *W14 


The iSBC 544 requires a -5V AUX input to the on-board RAM chips. 
The -5V AUX input to the on-board RAM chips can be supplied by the 
on- board -5V regulator or by an auxiliary backup battery. (The on- 
board -5V regulator operates from the system -12V supply). If a 
system -5V supply is available disconnect default jumper W14 from 
between *A-B and connect it between B-C. 


Input frequencies to 8253 Programmable Interval Timer counters are 
jumper selectable as follows: 

Counter 0, 1, 2, and 5 (8251 Baud Rate Clocks). 
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Table 2-3. Jumper Selectable Options (Cont’d.) 


FUNCTION 


Fig 5-1 Fig 5-2 

GRID REF GRID REF 




Timer Input 
Frequency 
(8155 Timer) 


Priority Interrupts 


Power Fail 


Timer Interrupt 


*30-29: 1.2288 MHz 
30-31 : 1 .8432 MHz 

Counter 4 (Secondary Baud Rate Clock). 

*30-29: 1.2288 MHz 
30-31: 1.8432 MHz 

Counters (Interval Timer) 

*33-32: Output of Counter 4. 

33-34: Same as Counters 0,1,2, 3, and 4. 

Jumper 33-32 effectively connects Counter 4 and Counter 5 in series 
in which the output of Counter 4 acts as the input clock for Counter 5. 
This allows for counting long time intervals (app. 1 hour total). 


Input frequencies to the 8155 Programmable Timer counter are 
jumper selectable as follows: 

*30-29: 1.2288 MHz 
30-31: 1.8432 MHz 


There are a number of interrupts which can be interfaced to the on- 
board 8085A. An explanation of each of these interrupts can be found 
in paragraph 2-14. The interrupts are jumpered as follows: 

90-91: PFIN/ (Power Fail Interrupt) jumper to TRAP 
input on 8085A. 

*49-50: TINTO (Timer Interrupt 0) jumpered to RST 7.5 
input on 8085A. 


Timer interrupt 


*47-48: TINT1 (Timer Interrupt 1) jumpered to RST 7.5 
input on 8085A. 


Flag Interrupt 


*43-44: PINT/ (Flag Interrupt) jumpered to RST 5.5 
input on 8085A. 


Bus Interrupts 
(Input) 


81-82: INTO/ 

81-83: INTI/ 

81-84: INT2/ 

81-85: INT3/ 

81-86: INT4/ 

81-87: INT5/ 

81-88: INT6/ 

81-89: INT7/ 

Bus Interrupts - jumpers one to RST 5.5 and SID 

inputs on 8085A. 


Bus Interrupt 
(output) 


80-82: INTO/ 
‘80-83: INTI/ 
80-84: INT2/ 
80-85: INT3/ 
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Table 2-3 . Jumper Selectable Options (Cont’d.) 


FUNCTION 

Fig 5-1 
GRID REF 

Fig 5-2 
GRID REF 

DESCRIPTION 




80-86: INT4/ 

80-87: INT5/ 

80-88: INT6/ 

80-89: INT7/ 






Jumpers SOD output of 8085A to one of the Bus 

Interrupt lines. SOD is 8085A’s interrupt output 




to the Multibus. 



Serial I/O Clocks 



Jumper wires as required to connect inputs to Transmit Clock (TXC) 

(Baud Rate) 



and Receive Clock (RXC) 
paragraph 2-16). 

of USART 

chips as follows (refer to 


C7 

8ZD6 

PORTO TXC 

RXC 

SOURCE 




*6-7 

*2-4 

BDGOfrom PITO 





1-2 

BDG4 from PIT 1 




5-6 

2-4 

XMIT CLK (external 
via J1) 





2-3 

REC CLK (external 
via J1) 


06 

8ZA6 

PORT1 TXC 

RXC 

SOURCE 




‘13-14 

*9-11 

BDG1 from PITO 





8-9 

BDG4 from PIT 1 




12-13 

9-11 

XMIT CLK (external 
via J2) 





10-9 

REC CLK (external 
via J2) 


05 

9ZD6 

PORT 2 TXC 

RXC 

SOURCE 




*20-21 

*16-18 

BDG2from PITO 





15-16 

BDG4 from PIT 1 




19-20 

16-18 

XMIT CLK (external 
via J3) 





17-16 

REC CLK (external 
via J3) 


04 

9ZA6 

PORTS TXC 

RXC 

SOURCE 




*27-28 

*23-25 

BDG3 from PIT 1 





22-23 

BDG4 from PIT 1 




26-27 

23-25 

XMIT CLK (external 
via J4) 





24-23 

REC CLK (external 
via J4) 

Serial I/O Port 



One 18-pin DIP header jumper assembly is supplied for each serial 

Interface 



I/O port. These DIP header jumper assemblies allow the serial I/O 
ports to interface with RS232C devices as a data terminal (refer to 




paragraph 2-17). 




D7 

8ZD3 

Port 0 - W1 




D6 

8ZB3 

Port 1 - W2 




D5 

9ZD3 

Port2-W3 




D4 

9ZB3 

Port3- W4 
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Table 2-3. Jumper Selectable Options (Cont’d.) 


FUNCTION 

Fig 5-1 
GRID REF 

Fig 5-2 
GRID REF 

DESCRIPTION 

TTY Adapter Interface 



One 8-pin header jumper socket is supplied for each serial I/O port to 

Power 



supply power to a TTY Adapter. The jumper plugs are assigned as 
follows: 


07 

8ZC3 

Port0-W5 


06 

8ZA3 

Port1-W6 


05 

9ZC3 

Port2-W7 


04 

9ZA3 

Port3-W8 




Note 




The user must supply his own jumper header plugs. 

Parallel I/O Port 

D3 


No optional jumpers 

Outputs 




Master Mode 

06 

4Z06 

Set position 8 of SI to on position. 


‘Default jumpers configured at the factory. 


2-14. PRIORITY INTERRUPTS 2-16. SERIAL I/O CLOCKS 


Table 2-3 lists the source and destination of the inter- 
rupts which can be generated on the iSBC 544. For 
example, the PINT/ (Flag Interrupt) which signifies 
an off-board write to the RAM’s base address 
generates an interrupt request to the RST 5.5 input 
on the 8085A. 

There are two areas which require some explanation: 
the 8085A TRAP and RST 5.5, 6.5, and 7.5 inter- 
rupts. 

The TRAP interrupt is useful for catastrophic errors 
such as power failure. On the iSBC 544, jumper 
91-90 will allow the connection of PFIN/ (Power 
Failure) from the Multibus to the TRAP input on the 
on-board 8085 A. The TRAP input is both level and 
edge sensitive. The TRAP interrupt has the highest 
priority, and can not be masked (disabled by the pro- 
gram). 

RST 5.5, 6.5 and 7.5 interrupts cause the internal ex- 
ecution of an RST. These interrupts can be masked 
by the program. RST 7.5 is rising edge-sensitive, and 
RST 6.5 and 5.5 are high level-sensitive. These inter- 
rupts are default (factory connected) jumpered as 
shown in table 2-3. 

2-15. COUNTER CLOCK FREQUENCY 

The normal counter clock frequency is 1.2288 MHz. 
To change this frequency to 1.8432 MHz for greater 
timing flexibility, remove jumper 29-30 and connect 
jumper 30-31. 


Each of the two Programmable Interval Timers (PIT 
0 and PIT 1) has three independent time/rate (Baud 
rate) generator sections as follows: 


Timer 

Counter 

Output 

PITO 

0 

BDGO 

PITO 

1 

BDGl 

PITO 

2 

BDG2 

PIT 1 

3 

BDG3 

PIT 1 

4 

BDG4 

PIT 1 

5 

TINTl 


There are four USART chips, one for each serial I/O 
port. Each USART chip, or serial I/O port, requires 
two clocks: a Transmit Clock (TXC) and a Receive 
Clock (RXC). These two clocks may be at the same 
frequency or at different frequencies. 

The default (factory connected) clock for each serial 
I/O port is listed in table 2-3. Note that BDGO serves 
as both TXC and RXC clock for Port 0, and that 
BDGl through BDG3 serve as both the TXC and 
RXC clocks for Port 1 through Port 3 respectively. 

Examination of table 2-3 shows that each port can 
accept inputs from five separate sources. Notice that 
each port can accept an externally supplied receive 
clock (REC CLK) and transmit clock (XMIT CLK). 
These clocks are input via the edge connector 
associated with each serial I/O port. 

Clock signals BDGO through BDG4 can be program- 
med for any integral submultiple of the iSBC 544 
clock frequency (1 .2288 MHz or 1 .8432 MHz). 
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2-17. SERIAL I/O PORT INTERFACE 

Each of the four serial 1/ O ports can be configured to 
accommodate RS232C devices. The iSBC 544 is sup- 
plied with four 18-pin DIP header jumper assemblies 
installed in sockets designated W1 through W4 to ac- 
commodate RS232C devices (refer to table 2-3). The 
jumper is set up for data terminal operation. To con- 
vert to data set operation see paragraph 2-21 . 

2-18. PARALLEL I/O PORT 

The parallel I/O port has six parallel output lines and 
four parallel input lines that are compatible with the 
Bell Model 801 Automatic Calling Unit (ACU), or 
equivalent. The inputs and outputs of the parallel 
I/O port are controlled by an Intel 8155 Program- 
mable Peripheral Interface (PPI) chip. 

2-19. INPUT OPTIONS 

Instead of the standard ACU input signals (PND, 
COS, DLO, and ACR), one input of each of the 
following pairs can be jumper-connected. 

a. SRXDO or CTSO/ 

b. SRXDlorCTSl/ 

c. SRXD2orCTS2/ 

d. SRXD3orCTS3/ 

The four SRXD inputs are from the four serial I/O 
ports respectively: the CTS inputs from the USART 
chips can be monitored when jumpered as shown in 
table 2-3. IC A5 must be removed before CTS 
jumpers can be inserted. 

2-20. OUTPUT OPTIONS 

Instead of the standard ACU outputs (number bits 
NBl, NB2, NB4, NB8, CRQ, and DPR) the follow- 
ing outputs are available: 

a. STXDO 

b. STXDl 

c. STXD2 

d. STXD3 

The four STXD outputs go to the four serial I/O 
ports, respectively. The Digit Present (DPR) and Call 
Request (CRQ) outputs are to an ACU. 

2-21. DATA SET CONVERSION 

Ports 0 through 3 are configured for data terminal 
operation in conjunction with an external data set. 
For certain applications, it may be necessary to con- 
vert one or more ports for data set operation in con- 
junction with an external data terminal. To convert 
to data set operation, proceed as follows: 

a. Select port to be converted and remove 
associated 18-pin DIP header jumper assembly; 

e.g., for Port 0, remove DIP header jumper 
assembly from W1 (refer to table 2-3). 


b. Wire a DIP header jumper assembly so that the 
following signals are reversed: (1) TXD and 
RXD, (2) RTS and CTS, and (3) DSR and DTR 
(see figure 2-1). Other signals may need to be 
reversed depending on the particular application. 

c. Place reconfigured DIP header jumper assembly 
in the appropriate IC socket: W1 for Port 0, W2 
for Port 1, W3 for Port 2, and W4 for Port 3. 


JUMPER 



DTE TxC (OPTIONAL) 

DSR 

DTR 

CTS 

RTS 

RxD 

TxD 

SRxD 

STxD 


Figure 2-1 . Reconfigured DIP Header Jumper 
Assembly for Data Set Operation. 


2-22. MULTIBUS CONFIGURATION 

For systems applications, the iSBC 544 is designed 
for installation in a standard Intel iSBC 604/614 
Modular Backplane and Cardcage (refer to table 2-1 
items 1 and 2). Alternatively, the iSBC 544 can be in- 
terfaced to a user-designed system backplane by 
means of an 86-pin connector (refer to table 2-1 item 
3). Multibus signal characteristics and methods of 
implementing a serial or parallel priority resolution 
scheme for resolving bus contention in a multiple bus 
master system are described in the following 
paragraphs. 


CAUTION 

Always turn off the system power supply 
before installing the board in or removing 
the board from the backplane. Failure to 
observe this precaution can cause damage to 
the board. 
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2-23. SIGNAL CHARACTERISTICS 


As shown in figure 1-1, connector PI interfaces the 
iSBC 544 to the Multibus. Connector PI pin 
assignments are listed in table 2-4 and descriptions of 
the signals are provided in table 2-5 . 


The dc characteristics of the iSBC 544 bus interface 
signals are provided in tables 2-6 and 2-7. 

The ac characteristics of the iSBC 544 bus interface 
signals are provided in tables 2-8 and 2-9. Bus ex- 
change and bus control timing is shown in figures 2-2 
and 2-3 respectively. 


Table 2-4. Multibus Connector PI Pin Assignments 



PIN* 

(COMPONENT SIDE) 

PIN* 

(CIRCUIT SIDE) 

MNEMONIC DESCRIPTION 

MNEMONIC 

DESCRIPTION 


1 

GND 

Signal GND 

2 

GND 

Signal GND 



+5V 

+5Vdc 

4 

+5V 

+5Vdc 

POWER 


+5V 

+5Vdc 

6 

+5V 

+5Vdc 

SUPPLIES 


+12V 

+12Vdc 

8 

+12V 

+12Vdc 



-5V 

-5Vdc 

10 

-5V 

-5Vdc 


11 

GND 

Signal GND 

12 

GND 

Signal GND 


13 

BCLK/ 

Bus Clock 

14 

mil/ 

Initialize 


15 


Reserved 

16 


Reserved 

BUS 

17 

BUSY/ 

Bus Busy 

18 


Reserved 

CONTROLS 

19 

MRDC/ 

Mem Read Cmd 

20 

MWTC/ 

Mem Write Cmd 



lORC/ 

I/O Read Cmd 

22 

lOWC/ 

I/O Write Cmd 



XACK/ 

XFER Acknowledge 

24 

INH1/ 

Inhibit 1 disable RAM 


25 


Reserved 

26 


Reserved 


27 


Reserved 

28 

AD10/ 



29 


Reserved 

30 

AD11/ 

Address 


31 

CCLK/ 

Constant Clk 

32 


Bus 

ADDRESS 

33 


Reserved 

34 




35 

EMM 

Parallel 

36 


Parallel 

INTERRUPTS 

37 

ISSH 

Interrupt 

38 


Interrupt 

39 

ISIH 

Requests 

40 


Requests 


41 

ISSH 


42 

INTI/ 



43 

ADRE/ 


44 

ADRF/ 



45 

ADRC/ 


46 

ADRD/ 



47 

ADRA/ 

Address 

48 

ADRB/ 

Address 

ADDRESS 

49 

ADR8/ 

Bus 

50 

ADR9/ 

Bus 


51 

ADR6/ 


52 

ADR7/ 



53 

ADR4/ 


54 

ADR5/ 



55 

ADR2/ 


56 

ADR3/ 



57 

ADRO/ 


58 

ADR1/ 



59 


Reserved 

60 


Reserved 


61 


Reserved 

62 


Reserved 


63 


Reserved 

64 


Reserved 

DATA 

65 

DAT8/ 


66 

DAT9/ 



67 

DAT6/ 

Data 

68 

DAT7/ 

Datfl 


69 

DAT4/ 


70 

DAT5/ 



71 

DAT2/ 


72 

DAT3/ 



73 

DATO/ 


74 

DAT1/ 



75 

GND 

Signal GND 

76 

GND 

Signal GND 


77 


Reserved 

78 


Reserved 

POWER 

79 

-12V 

-12Vdc 

80 

-12V 

-12Vdc 

SUPPLIES 

81 

+5V 

+5Vdc 

82 

+5V 

+5Vdc 


83 

+5V 

+5Vdc 

84 

+5V 

+5Vdc 


85 

GND 

Signal GND 

86 

GND 

Signal GND 


* All odd-numbered pins (1,3, 6.. .85) are on component side of the board. Pin 1 is the left-most pin when viewed from the 
component side of the board with the extractors at the top. All unassigned pins are reserved. 
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Table 2-5 . Multibus Signal Functions 


SIGNAL 

FUNCTIONAL DESCRIPTION 

ADR0/-ADRF/ 

ADR10/-ADR13/ 

Address . These 20 lines transmit the address of the memory location or I/O port to be accessed. 
ADRF/ is the most-significant bit except where ADR10/ through ADR13/ are used. ADR10/ 
through ADR13/ are transmitted only by those bus masters capable of addressing beyond 64K 
of memory. In this case, ADR13/ is the most-significant bit. 

BCLK/ 

Bus Clock . Used to synchronize the bus contention logic on all bus masters. When generated by the 
iSBC 544, BCLK/ has a period of 180.84 nanoseconds (5.530 MHz) with a 35-65 percent duty cy- 
cle. (Does not conform to Multibus specifications). 

BUSY/ 

Bus Busy . Indicates that the bus is in use and prevents all other bus masters from gaining control of 
the bus. BUSY/ is not synchronized with BCLK/ on the iSBC 544. 

CCLK/ 

Constant Clock . Provides a clock signal of constant frequency for use by other system modules. 
When generated by the iSBC 544, CCLK/ has a period of 180.84 nanoseconds (5.530 MHz) with a 
35-65 percent duty cycle. (Does not conform to Multibus Spec.) 

DAT0/-DAT7/ 

Data . These eight bidirectional data lines transmit and receive data to and from the addressed 
memory location or I/O port. DAT7/ is the most-significant bit. 

INH1/ 

Inhibit RAM . Prevents bus access to on-board RAM. Used to have PROM overlap iSBC 544 RAM. 

INIT/ 

Initialization . Resets the entire system to a known internal state. 

INT0/-INT7/ 

Interrupt . These eight lines are for inputting interrupt requests to the iSBC 544. INTO/ has the highest 
priority; INT7/ has the lowest priority. These lines may also be used to interface an interrupt 
signal from the iSBC 544 to the multibus. 

lORC/ 

I/O Read Command . . Indicates that the address of an I/O port is on the Multibus address lines and 
that the output of that port is to be read (placed) onto the data lines. 

lOWC/ 

I/O Write Command . Indicates that the address of an I/O port is on the Multibus address lines and 
that the contents on the Multibus data lines are to be accepted by the addressed port. 

MRDC/ 

Memory Read Command . Indicates that the address of a memory location is on the Multibus 
address lines and that the contents of that location are to be read (placed) on the Multibus data 
lines. 

MWTC/ 

Memory Write Command . Indicates that the address of a memory location is on the Multibus address 
lines and that the contents on the Multibus data lines are to be written into that location. 

XACK/ 

Transfer Acknowledge . Indicates that the addressed memory location or I/O port has completed the 
specified read or write operation. That is, data has been placed onto or accepted from the 
Multibus data lines. 


2-11 









Preparation For Use 


iSBC 544 


Table 2-6. iSBC 544 DC Characteristics - Slave Mode 


SIGNAL 

SYMBOL 

PARAMETER 

TEST 

CONDITIONS 

MIN . 

MAX. 

UNIT 

ADR0/-ADR13/ 


Input Low Voltage 

Vcc = 5.0V 


0.8 

V 



Input High Voltage 

Vcc = 5.0V 

2.0 


V 



Input Current at Low V 

V|N = 0.4V 


-0.47 

mA 



Input Current at High V 

V|n = 2.7V 


200 

mA 


IH 

Capacitive Load 



18 

PF 

DAT0/-DAT7/ 

Vql 

Output Low Voltage 

Iql = 50 mA 


0.6 

V 


Vqh 

Output High Voltage 

'oh = “"'0 

2.4 


V 


V|L 

Input Low Voltage 



0.95 

V 


V|H 

Input High Voltage 


2.0 




l| 

Input Current at Low V 

V|N = 0.45 V 


-0.25 



II 

Output Leakage High 

Vo = 5.25 V 


100 



*Cl 

Capacitive Load 



18 

jm 

INH1/ 

V|L 

Input Low Voltage 



0.8 

V 


VlH 

Input High Voltage 


2.0 


V 


l|L 

Input Current at Low V 

V|N =0.5V 


-2 

mA 


l|H 

Input Current at High V 

V|n=2.2V 


50 

mA 


Cl 

Capacitive Load 




pF 

iNT0/-iNT7/ 


Output Low Voltage 

IOL = "'6 mA 


0.4 

V 



Output High Voltage 

OPEN COLLECTOR 





ISM 

Capacitive Load 



18 

pF 

INIT/ 

V|L 

Input Low Voltage 



0.8 

V 


V|H 

Input High Voltage 


2.0 


V 


l|L 

Input Current at Low V 

V|N =0.4V 


-2.2 

mA 


>IH 

Input Current at High V 

V|N = 2.4V 


-80 

mA 


Cl 

Capacitive Load 




pF 

MRDC/ 

V|L 

Input Low Voltage 



0.8 

V 

MWTC/ 

V|H 

Input High Voltage 


2.0 


V 


l|L 

Input Current at Low V 

V|N = 0.45V 

-1.6 


mA 


'iH 

Input Current at High V 

ViN = 2.4V 

80 


mA 


Cl 

Capacitive Load 




pF 

RS232C 

VjH 

Input High Threshold Voltage 


1.75 

2.25 

V 

inputs 

Vtl 

Input Low Threshold Voltage 


.75 

1.25 

V 


1 

Input Current 

V| = +3V 

+.43 


mA 




< 

z 

II 

1 

CO 

< 

-.43 


mA 

RS232C 

Vo 

High Level Output Voltage 


n 


V 

Outputs 

Vo 

Low Level Output Voltage 


wSm 

-12.0 

V 


•o 

High Level SS Output Current 


Bfl 


mA 


•os“ 

Low Level SS Output Current 


HI 

12.0 

mA 

XACK/ 


Output Low Voltage 

Iql = 32mA 

WM 

0.4 

V 



Output High Voltage 

Iqh = -5.2mA 



V 



Output Leakage High 

Vo = 2.4V 

HH 

40 

mA 



Output Leakage Low 

Vo = 0.4V 


--40 

mA 



Capacitive Load 


■ 

15 

pF 


‘Note: Capacitive Loads are approximate. 
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Table 2-7. iSBC 544 DC Characteristics - Master Mode 


SIGNAL 

SYMBOL 

ADR0/-ADRF/ 

Vql 


Vqh 


Ilh 


'll 


Cl 

ADR10/-ADR13/ 

Vqh 

BCLK/ 

Vql 


Vqh 

BUSY/ 

Vql 

(OPEN COLLECTOR) 

Cl 

CCLK/ 




INIT/ 

(SYSTEM RESET) 


MROC/, MWTC/ 
lORC/, lOWC/ 









PARAMETER 

TEST 

CONDITIONS 

Output Low Voltage 

Output High Voltage 

Output Leakage High 
Output Leakage Low 
Capacitive Load 

Iql = 15mA 

VoH = -1mA 

Vo = 4V 

Vo = 0.45V 

Output High Voltage 

Iqh = 87 mA 

Output Low Voltage 

Output High Voltage 

•oh = 40 mA 
•oh “2mA 

Output Low Voltage 
Capacitive Load 

•oL = 40mA 

Output Low Voltage 

Output High Voltage 
Capacitive Load 

•OL = 40mA 
•oh = “2mA 

Output Low Voltage 

Output High Voltage 

Input Low Voltage 

Input High Voltage 

Input Current at Low V 
Output Leakage High 
Output Leakage Low 
Capacitive Load 

•oL = 80 mA 
•oh = “10 mA 

V|N = 0.45V 

Vo = 5.25V 

Vo = 0.45V 

Output Low Voltage 

Output High Voltage 

Input Low Voltage 

Input High Voltage 

Input Current at Low V 

Input Current at High V 
Capacitive Load 

•oL = 40mA 

OPEN COLLECTOR 

V,n = .4V I 

V|N = 2.4V 

Input Low Voltage 

Input High Voltage 

Input Current at Low V 

Input Current at High V 
Capacitive Load 

V,N = .4V 

V|N = 2.4V 

Output Low Voltage 

Output High Voltage 

Output Leakage High 

Output Leakage Low 
Capacitive Load 

•oL = 32mA 

VoH = -5.2mA 

Vo = 2.4V 

Vo = 0.45V 

Input Low Voltage 

Input High Voltage 

Input Current at Low V 

Input Current at High V 
Capacitive Load 

V|N = 0.4V 

V|N = 2.4V 



MAX. 

UNIT 

0.5 

V 


V 

200 

mA 

-0.52 

mA 

18 

PF 






















"Note: Capacitive Loads are approximate. 
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Table 2-8. iSBC 544 AC Characteristics - Slave Mode 


Parameter 


Minimum Maximum 
(nsec)** (nsec)** 


Description 


Address setup to command 


Write data setup to command 


Command to transfer acknowledge time 


Address hold time 


Write data hold time 


Read data hold time 


Acknowledge turnoff delay 


Access time to read data 


Inhibit hold time from command trailing edge 


Inhibit Pulse Width 


Minimum cycle time 


On-board Memory Cycle Delay 


On-board Memory Cycle Delay 


Refresh delay time 


Refresh interval 


Inhibit setup to command 


Command Separation 


* When an asynchronous refresh cycle occurs, tpQ is added to these parameters, when on-board memory cycle 
occurs, tQ0-| 2 is also added. 

** Except where noted. 
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Table 2-9. iSBC 544 AC Characteristics - Master Mode 


Parameter 

Write 

10 Read 

Mem Read 

Description 

Remarks 

Min 

(ns) 

Max 

(ns) 

Min 

(ns) 

Max 

(ns) 

Min 

(ns) 

Max 

(ns) 

‘as 

330 


200 


50 


Address Setup Time to Command 


Uh 

50 


50 


50 


Address Hold Time 


'ds 

95 






Data Setup Time to Command 


^DH 

50 


0 




Data Hold Time 


^ACKO 

-365 

5 

-135 

135 

50 

310 

First ACK Sampling Point of Current Cycle 

Generates 0 Wait States 

tACK1 

0 

365 

230 

500 

410 

675 

Second ACK Sampling Point of Current Cycle 

Generates 1 Wait State 

tACK2 

360 

730 

590 

860 

770 

1040 

Third ACK Sampling Point of Current Cycle 

Generates 2 Wait States 

<CY 


362 





ACK Sample Cycle Time 


*SEP 





200 


Command Separation 


%C 

280 

450 

430 

550 

593 

775 

Command Width 

1 

^ACC 




245 


420 

Read Access Time 

1 

<XKD 

0 


0 




XACK Delay From Valid Data or Write 


^XKO 

0 

100 

0 

100 

0 

100 

XACK Turn Off Delay 


^BCY 


181 





Bus Clock cycle Time 

544 Generator 

^BW 

70 

120 





Bus Clock Low or High Periods 

544 Generator 

t|NT 

3000 






Initialization Width 

After all voltages have stabilized 


1 Assumes 0 Wait States. Each Wait State adds 362 ns 

2 Read Command to next Read Command separation. 
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2-24. POWER FAIL/MEMORY 

PROTECT CONFIGURATION 


If the Battery Backup feature is to be used a mating 
connector must be installed in the iSBC 604/614 
Modular Cardcage and Backplane to accommodate 
the auxiliary connector P2 (refer to figure 1-1). Table 
2-2 is a list of some of the 60-pin connectors that can 
be used for this purpose. Table 2-10 correlates the 
signals and pin numbers on the connector. 

Procure the appropriate mating connector for P2 and 
secure it in place as follows: 

a. Position holes in P2 mating connector over 
mounting holes that are in line with correspon- 
ding PI mating connector. 

b. From top of connector, insert two 0.5-inch /4-40 
pan head screws down through connector and 
mounting holes. 

c. Install a flat washer, lock washer, and star-type 
nut on each screw; then tighten the nuts. 

When mating connector for P2 is in place, wire the 
power fail signals to the appropriate pins of the 
connector as listed in table 2-10. In a typical system, 
these signals would be wired as follows: 


Table 2-10. Auxiliary Connector P2 Pin Assignments 


Pin* 

Signal 

Definition 

1 

GND 

1 

^ Auxiliary common 


GND 


1 

mm 

-I-5VAUX 



H 

-t-5V AUX 



■ 

-5V AUX 


Auxiliary backup battery supply 

B 

-5V AUX 



11 

-1- 12V AUX 



12 

-)-12VAUX 



19 

PFI/ 

Power Fail Interrupt. This externally supplied signai is applied to the priority interrupt 
matrix. This signal should normally be jumpered to the 8085A microprocessor TRAP in- 
put. 

20 

MEM PROT/ 

Memory Protect. This externally supplied signal prevents access to RAM during battery 
backup operation. 

28 

HLT/ 

Halt. This output signal indicates that the 8085A microprocessor is halted. 

38 

AUX RESET/ 

Auxiliary Reset. This externally supplied signal initiates a power-up sequence; i.e., 
initializes the board and resets the entire system to a known internal state. 

* All odd-numbered pins (1.3, 5. ..59) are on component side of the board. Pin 1 is the left-most pin when viewed from the 
component side of the board with the extractors at the top. 


a. Connect auxiliary signal common and returns for 
-1-5 V, -5V, and +12V backup batteries to P2 pins 
1 and 2. 

b. Connect +5V battery input to P2 pins 3 and 4, 
-5V battery input to P2 pins 7 and 8 and +12V 
battery input to P2 pins 11 and 12. Remove 
jumpers W12, W13, and W14. 

c. Connect MEM PROT/ input to P2 pin 20. 

d. Connect PFIN/ input to P2 pin 19. To assign the 
PFIN/ input as the highest priority interrupt 
(8085A TRAP) connect jumper 90-91 . 

e. Connect HALT/ output at P2 pin 28 to external 
HALT indicator; which is typically a light- emit- 
ting diode (LED) mounted on the system 
enclosure. 

f. Connect AUX RESET/ input to P2 pin 38. This 
signal is usually supplied by a momentary closure 
switch mounted on the system enclosure. 


2-25. SERIAL I/O CABLING 

The four serial I/O ports can be used with an RS232C 
device. Connection details for the devices are given 
in the following paragraphs. Compatible mating 
connectors for J1 through J4 are listed in table 2-2. 
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Pin assignments and signal definitions for RS232C 
serial I/O communications are listed in table 2-11. 
Each of the four serial I/O ports is configured for 
data terminal operation. As described in paragraph 
2-21, each port can alternatively be configured for 
data set operation by rewiring the DIP header jumper 
assembly. 


The Intel iSBC 955 Cable Set consisting of two cable 
assemblies, is recommended for RS232C interfacing. 
One cable assembly consists of a 25-wire flat cable 
with a 26-pin PC edge connector at one end and an 
RS232C interfacing connector at the other end. The 
second cable assembly includes an RS232C connector 
at one end and has spade lugs at the other end; the 
spade lugs are used to interface to a teletypewriter. 
See Appendix B for ASR 33 TTY interface instruc- 
tions. An iSBC-530 TTY Adapter is required to inter- 
face to a TTY. 


For OEM applications where cables will be made for 
the iSBC 544, it is important to note that the mating 
connectors for J1 through J4 have one more pin (26) 
than an RS232C interface connector (25), which is 
used with a 25 -wire flat cable. Consequently, when 
wiring the 26-pin mating connector, be sure that the 
cable makes contact with pins 1 and 2 of the mating 
connector, and not with pin 26. 

Similarly, when installing the iSBC 544 with a 26-pin 
mating connector (J1 through J4), be sure that the 
connector is orientated properly on the serial I/O 
ports. If the connector is installed backward, no 
damage will occur but the I/O port will be in- 
operative. 


NOTE 

The numbers on the iSBC 544 card edge con- 
nector do not necessarily correspond with 
numbers on mating connectors. 


Table 2-11. Connector J1-J4 RS232C Signal Interface 


Pin 

RS232C 

Pin 

Signai 

Mnemonic 

Definition 

1 

14 

STXD 

Secondary Transmit Data. Same as TXD except STXD is a secondary 
signal. 

2 

1 

FGD 

TTY Frame Ground. (Optional jumper plug) 

3 

15 

XMITCLK 

Transmit Clock. External input clock signal for transmit data timing. 

4 

2 

TXD 

Transmit Data. Data transmitted from data terminal to data set. 

5 

16 

SRXD 

Secondary Receive Data. Same as RXD except SRXD is a secondary 
signal. 

6 

3 

RXD 

Receive Data. Data received by data terminal from data set. 

7 

17 

RECCLK 

Receive Clock. External input clock signal for receive data timing. 

8 

4 

RTS 

Request To Send. Control signal from data terminal to data set; sets 
data set in transmit mode. 

9 

18 

- 

Not used on iSBC 544. 

10 

5 

CTS 

Clear To Send. Control signal from data set to data terminal to indicate 
that data set is ready to transmit data; enables TXD output mode. 

11 

19 

- 

Not used in iSBC 544. 

12 

6 

DSR 

Data Set Ready. Indicates to data terminal that data set is connected to 
a communications channel; i.e., data set is not in Test, Talk, or Dial 
mode and timing and/or answer signals have been completed. 

13 

20 

DTR 

Data Terminal Ready. Indicates to data set that data terminal is ready to 
transmit or receive data. 

14 

7 

SGD 

Signal Ground. 

15 

21 

— 

Not used on iSBC 544. 

16 

8 

CD 

Carrier Detect. Signal from data set; indicates that data set is receiving 
a suitable signal. 
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Table 2-1 1 . Connector J1-J4 RS232C Signal Interface (Cont’d.) 


J1-J4> 

Pin 

RS232C 

Pin 

Signai 

Mnemonic 

Definition 

17 

22 

Rl 

Ring indicator. Signal from data set; indicates that ringing signal has 
been received from a communications channel. 

18 

9 

— 

Not used for RS232C. 

19 

23 

- 

TTY Adapter PWR (-12V). (Optional jumper plug) 

20 

10 

— 

Not used for RS232C. 

21 

24 

DTE TXC 

Data Terminal Equipment Transmit Clock. Output from serial I/O port to 
data set to provide clock signal to transmitting signal converter. 

22 

11 

- 

TTY Adapter PWR ( + 12V). (Optional jumper plug) 

23 

25 

— 

TTY Adapter PWR ( + 5V). (Optional jumper plug) 

24 

12 

- 

Not used for RS232C. 

25 

N/C 

SGD 

Signal Ground. 

26 

13 

— 

Not used for RS232C. 

NOTES: 




1. J1-J4 pins 9, 11, 15, 18, 20, 24, and 26 are not used by iSBC544. 

2. Pin numbers refer to board connector pins only, they are not necessarily the same on the mating connectors. 


Table 2-12. Connector J5 Parallel Output Signal Interface 


J5 

Pin 

RS232C 

Pin 

Signal 

Mnemonic 

Description 

1 

14 

NB1 




15 

NB2 


Number Bit Lines. Binary Coded decimal (BCD) bits that indicate digits of number 


16 

NB4 


being called. 


17 

NB8 




2 

DPR 


Digit Present. Generated by data terminal; signal true indicates outputs NB1-NB8 





have been set by data terminal and can be read by ACU . 


3 

ACR 


Abandon Call; Retry. Generated by ACU to indicate that a call has failed (busy, no 





answer, dead line). Signal true suggests that if call has not been completed, it 
should probably be abandoned and retried later. 

8 

4 

CRQ 


Call Request. Generated by data terminal; signal true indicates a request for ACU 





to originate a call. 

10 

5 

PND 


Present Next Digit. Generated by ACU during dialing; signal true indicates ACU is 





ready to accept next digit output on NB lines. Signal false indicates data terminal 
must reset DPR output. PND will not be set true as long as DPR remains true. PND 
will be set true after data terminal resets DPR false after last digit on NB lines. 
PND will be true for duration of any call placed by ACU. PND will be false 
throughout ail calls placed manually and throughout all incoming calls. 

14 

7 

SGD 


Signal Ground. 

23 

25 




21 

24 



Not used by ISBC 544. 

16 

8 
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Table 2-12. Connector J5 Parallel Output Signal Interface (Cont’d.) 


J5 

Pin 

RS232C 

Pin 

Signal 

Mnemonic 

Description 

22 

11 

AUXO 

> Auxiliary outputs; require jumper connection. (Refer to paragraph 2-20.) 

24 

12 

AUX1 

) 

17 

22 

DLO 

Data Line Occupied. Generated by ACU; signal true indicates to data terminal that 
data channel is in use. 

26 

13 

COS 

Call Origination Status. True indicates completed call. 

Notes: 




1. ACU is Automatic Caiiing Unit. 


2 Pin numbers refer tO board connector pins only, they are not necessarily the same on the mating connectors. 


2-26. PARALLEL I/O CABLING 

The parallel I/O port can be interfaced with the Intel 
iSBC 955 Cable Set described in paragraph 2-4. Pin 
assignments and signal definitions for the parallel 
I/O port are listed in table 2-12. Compatible mating 
connectors for J5 are listed in table 2-2. 


2-27. BOARD INSTALLATION 

CAUTION 

Always turn off the computer system power 
supply before installing or removing the 
iSBC 544 board and before installing or 
removing device interface cables. Failure to 
take these precautions can result in damage 
to the board. 

If an iSBC Single Board Computer based system, in- 
stall the iSBC 544 in any slot that has not been wired 
for a dedicated function. In an Intellec Microcom- 
puter Development System, install the iSBC 544 in 
any slot except slot 1 or 2. Attach the appropriate 
cable assemblies to connectors J1 through J5. 
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CHAPTER 3 
PROGRAMMING INFORMATION 


3-1. INTRODUCTION 

The iSBC 544 Intelligent Communications Controller 
can operate in two modes: 

a. Intelligent Slave Mode 

b. Single Board Communications Computer 

The first part of the this chapter will discuss the pro- 
gramming of the 544 as an intelligent slave, and the 
latter part will discuss the programming of the 544 as 
a bus master. 


3-2. INTELLIGENT SLAVE CONCEPT 

When the iSBC 544 operates as an intelligent slave, it 
can unburden a communications bound iSBC pro- 
cessor and perform such functions as format control, 
code conversions, data link control, error checking, 
data compression and buffer management. The 544 
is capable of performing these functions, because of 
its architecture which consists of: 

a. A dedicated 8085 A CPU which controls the 
operation of the on-board memory and the on- 
board I/O devices. 

b. Up to 8K bytes of ROM/PROM and 256 bytes of 
static RAM which are accessible only by the on 
board processor. 

c. Dual port memory which is accessible from both 
the internal processor bus and the external 
system bus. This memory provides the primary 
means of communication between the on board 
processor and an external master. 

d. Serial I/O which consists of four RS232C 
compatible I/O ports for interfacing with such 
things as data terminals, data sets, or other 
peripherals. 

e. Parallel I/O which provides compatability with a 
Bell 801 Automatic Calling Unit (ACU), and ad- 
ditional lines for auxiliary control of external 
devices such as data sets and peripherals. 

f. Interrupt control which provides the 
communication link between the on-board pro- 
cessor and the on-board I/O, and between the 
on-board processor and the system bus master. 

With this architecture, the iSBC 544 can perform all 
the jobs unique to the I/O without constantly access- 
ing the system bus and slowing down the master 
CPU. The 544 takes its direction from the master 
CPU, performs the necessary functions to interface 
with the external devices, controls the raw data 


transfer between I/O and memory, interrupts the bus 
master, and allows the bus master access to the on- 
board memory to retrieve the raw data or to enter 
raw data to be transferred to the external devices. 

Operating in this manner, the iSBC 544 can maximize 
I/O throughput and minimize the impact on the 
system bus, which will allow for better throughput 
between the master CPU, system memory, and 
system I/O. 


3-3. INTELLIGENT SLAVE 
PROGRAMMING 

The programming of the iSBC 544 in the intelligent 
slave mode is separated into two parts: (1) system 
programming, and (2) local or on-board programm- 
ing. The system programming concerns itself with the 
communication between the bus master (CPU) and 
the 544 (through the on-board 8085 A). The local pro- 
gramming concerns itself with the on-board com- 
munication between the 8085 A and the I/O devices. 
The following paragraphs describe these two aspects 
of the iSBC 544 programming. 


3-4. SYSTEM PROGRAMMING 

In the system programming environment, the iSBC 
544 appears to be nothing more than an additional 
RAM memory module. The master CPU com- 
municates with the iSBC 544 as if it were just an ex- 
tension of system memory. Because the iSBC 544 is 
treated as memory by the system, the user is able to 
program into it a command structure which will 
allow the iSBC 544 to control its own I/O and 
memory operation. To enhance the programming of 
the iSBC 544, the user has been given some specific 
tools. The tools are; 1) the flag interrupt, 2) System 
bus RAM always mapped into on-board RAM at 
location 8000H. All iSBC 544 ’s programmed with 
some firmware, 3) access to the bus interrupt lines. 


The Flag Interrupt is generated anytime a write com- 
mand is performed by an off-board CPU to the base 
address of the iSBC 544’s RAM. This interrupt pro- 
vides a means for the master CPU to notify the iSBC 
544 that it wishes to establish a communication se- 
quence. In systems with more than one intelligent 
slave, the flag interrupt provides a unique interrupt 
to each slave outside the normal eight bus interrupt 
lines. 
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The on-board RAM area that is accessible to both the 
master CPU and the on-board 8085A can be 4K, 8K 
or 16K, and can be located on any 4K boundry in the 
system. Whatever address is picked as the base ad- 
dress of the iSBC 544’s RAM, is the address that will 
cause a flag interrupt when written into by the master 
CPU. This provides a unique interrupt to every in- 
telligent slave on the system. Figure 3-1 shows the 
relationship of the on-board RAM to the system 
RAM. 

The iSBC 544 can both exercise and respond to bus 
interrupts. With these tools in mind, the user can 
now develop his own command structure for the 
iSBC 544. The following paragraphs will give the 
user a possible approach to developing his own com- 
mand structure for communicating with the iSBC 
544. 


The first byte in this communications area would be a 
command byte. This command byte could consist of 
a number of different simple commands such as: 


a. Execute — which would cause the iSBC 544 to 
perform an instruction or series of 
instructions. 


b. Reset — 


c. Stop — 


d. Test — 


which would cause the iSBC 544 to 
reset all the peripheral devices by 
executing a series of codes. 

which stops the execution of the 
instruction that the iSBC 544 is 
currently doing, and interrupts the 
master. 

would cause the iSBC 544 to write 
its status into the status byte(s). 


3-5. COMMUNICATIONS AREA. The user 
must first reserve an area that can be set aside as a 
communications area between the master CPU and 
the on-board 8085A. For example this area could 
consist of the first 8 locations in the on-board RAM 
and would contain the information shown in figure 
3-2. 


or some complex command such as Transmit Data 
which would cause the iSBC 544 to transmit a block 
of data from one of its serial I/O ports. This com- 
mand would require additional information such as 
what port, how much data, transfer speed, etc. The 
actual commands used will depend on the users 
specific application. 


SYSTEM 

ADDRESSES 


ON-BOARD 

ADDRESSES 


FOOOH 

EOOOH 

DOOOH 

COOOH 

BOOOH 

AOOOH 

9000H 

BOOOH 

7000H 

6000H 

5000H 

AOOOH 

3000H 

2000H 

1000H 



FOOOH 

EOOOH 

DOOOH 

COOOH 

BOOOH 

AOOOH 

9000H 

BOOOH 

7000H 

BOOOH 

5000H 

AOOOH 

BOOOH 

2000H 

1000H 


Figure 3-1 . iSBC 544 Memory Addressing 


A SYSTEM WRITE TO 

BOOOH (ON BOARD) THIS LOCATION GENERATES A 

SWITCH SELECTABLE 

OFF BOARD ON AK 
BYTE BOUNDARY. BASE 

BASE + 1 

BASE + 2 

BASE -F 3 

BASE -t- A 

BASE -t- 5 

BASE -t- 6 

BASE 7 

BASE -I- B 


Figure 3-2. Communications Area 


ADDRESS LB 


ADDRESS HB 


STATUS 


STATUS EXTENSION 


STATUS EXTENSION 


ADDRESS LB 


ADDRESS HB 


FLAG INTERRUPT. 

AN ON-BOARD READ TO 
THIS LOCATION CLEARS 
THE FLAG INTERRUPT. 
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The next two bytes in the communications area 
would be the command address. This address could 
be the location where the iSBC 544 would find the 
additional information to perform the command. 
For example, in the case of the EXECUTE command 
this is location the CPU would jump to for the begin- 
ning of the instruction string. 

The next byte in the communications area, would be 
the status byte. This byte is used by the on-board 
8085 A to communicate its status to the Master CPU. 
This status byte might contain such things as busy, 
done, error, etc. Typically, status cannot be com- 
municated in one byte, so status extension bytes are 
necessary. These bytes could contain specific in- 
formation such as the type of error, or the status of a 
particular port. 

The next two locations are address locations which 
could be used to tell the off board processor where it 
can find the information it requested on a Receive 
command, or additional status. 

It should be noted again, that this is simply an exam- 
ple of how a communications area could be set up. 
The actual number of locations used, and the con- 
tents of these locations is strictly up to the user. 

3-6. COMMUNICATIONS PROTOCOL. When 
using the communications area, some type of control 
has to be exercised over the master CPU and the on- 
board 8085A so that they don’t interfere with each 
other. This is done, by following some simple rules 
when setting up the software. 

The first rule deals with the command byte. The off- 
board processor can only write a command byte into 
the base location of RAM if the location is zero. The 
on-board processor will zero the location after it 
reads it. The only time the on-board processor reads 
the command byte location, is when it gets a Flag In- 
terrupt. This insures that the off-board processor has 
written a new command into this location. The Flag 
interrupt is cleared when the base address is read by 
the on-board processor. 

The second set of rules deals with the status byte. The 
on-board processor can only write status when the 
status-byte location is zero. The status-byte location 
is zeroed by the system processor when it has read 
status. 

3-7. COMMUNICATIONS PROGRAM SE- 
QUENCE. The following discussion will explain the 
events necessary to execute a command sequence. 
The discussion will point out the steps that must be 
accomplished by both the system CPU, and by the 
on-board CPU. Figure 3-3 is a flow chart of this 
sequence. 


The sequence starts with the system CPU checking 
the command byte location (Base) for zero. Finding 
it zero, the system CPU will write a command ad- 
dress into locations (Base -I- 1) and (Base + 2) and 
then a command into location (Base). This causes a 
Flag Interrupt to be generated. 

The on-board processor detecting the Flag Interrupt 
reads the command byte location to determine what 
is to be done (this clears interrupt). It determines 
what to do by checking the command against the 
Command Interpreter which has been stored in 
memory. Once the type of command is determined, 
the command address is loaded and the command 
byte cleared. 

The on-board processor then writes a status byte in 
the status byte location (Base -I- 3) to inform the 
system CPU that the command byte has been read, 
and that it can be executed. The on-board processor 
may interrupt the system CPU by way of a Multibus 
interrupt line to tell it to read the status byte. After 
generating the interrupt, the on-board processor 
starts executing the command. The system processor 
reads the status byte, clears it, and then readies itself 
to issue another command. The on-board processor 
will continue to execute the command, and will load 
additional status into the status byte location if 
necessary. At the completion of the command, the 
on-board processor will notify the system CPU by 
way of the interrupt line and status byte. This will 
cause the system CPU to jump out of its routine to 
determine what to do next, which might be to issue 
another command to the iSBC 544. 

Again, this is only a typical sequence and will vary 
somewhat depending on the type of commands that 
the user decides to use. 


3-8. COMMAND STRUCTURE. Commands like 
Execute can cause the iSBC 544 to execute a string of 
machine coded instructions. This creates no problem 
on simple commands, however to perform a complex 
function many bytes of code could be required. In 
order to simplify system programming of the iSBC 
544, it is beneficial for the user to create a set of 
“macro-like” instructions which can perform a 
higher level function such as; set Baud rate generator 
X to XXXX, initialize USARTX to mode XXX, etc. 
The user could then write his program in a series of 
high level macro’s which would require less bytes of 
memory and take up much less system time to 
transfer. To do this however, would require the user 
to have a library of these instructions stored in his 
PROMS. These instructions however, could be used 
over and over by the different programs that the 
iSBC 544 would be executing. Some of the types of 
high level instructions that could be used are shown 
throughout chapter three as programming examples. 
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Figure 3-3 . Communications Program Flow Chart 


3-9. ON-BOARD PROGRAMMING 

The on-board programming for the iSBC 544 will be 

presented by giving a detailed description of the pro- 
gramming of the following Intel chips: 

a, Intel 8253 PIT (Programmable Interval Timer) 
that controls various frequency and timing func- 
tions, 

b, Intel 8259 PIC (Programmable Interrupt Con- 
troller) that can handle up to eight vectored 
priority interrupts for the on-board micro- 
processor. 

c, Intel 8155 Programmable Timer that supplies the 
on-board 8085 A with an interval timer output. 

d, Intel 8155 Programmable Peripheral Interface 
which controls the parallel I/O port. 

e, Intel 8251 A US ART (Universal Synchronous/ 
Asynchronous Receiver/Transmitter) that con- 
trol the four serial I/O ports. 


f. Intel 8085A Microprocessor interrupt capability 
only, will be discussed. The instruction set for 
the 8085A is included in Appendix A; a complete 
description of programming with Intel’s assem- 
bly language is given in the 8080/8085A 
Assembly Language Programming Manual, 
Manual Order No. 98-310. 

In addition to the afore mentioned programming, 
this chapter also lists the on-board memory and I/O 
addresses and describes the effects of a system in- 
itialize command. 

3-10. SYSTEM INITIALIZATION 

When power is initially applied to the system, an in- 
itialize (INIT/) signal is automatically generated that 
clears the 8085A internal Program Counter, Instruc- 
tion Register, and Interrupt Enable flip-flop and 
resets the Dual Port Logic, Flag Interrupt Logic, 
Master Mode Flop, and the 8155 Programmable 
Peripheral Interface. The 8155’s I/O port is set to the 
input mode. 
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The initialize (INIT/) signal can also be generated by 
an auxiliary RESET switch. Depressing and releasing 
the RESET switch produces the same effect as the 
INIT/ signal described above. 

The 8251A USART’s must be initialized prior to pro- 
cessing. This is accomplished by programming the 
8155 PPL Refer to paragraph 3-39 for a detailed 
explanation of this procedure. 

3-11. MEMORY ADDRESSING 

The iSBC 544 which includes two IC sockets to ac- 
commodate up to 8K of user installable PROM is 
available with 16K of dynamic RAM and 256 bytes 
of static RAM. The iSBC 544 features a two-port 
RAM access arrangement in which the on- board 
RAM can be accessed by the on-board 8085 A 
microprocessor or by a bus master board via the 
Multibus. The EPROM and the 256 byte static RAM 
can only be accessed by the on-board 8085A. 

The on-board RAM can be accessed by a bus master 
that currently has control of the Multibus. It should 
be noted however, that even though the bus master 
may be accessing the iSBC 544 on-board memory, 
this does not lock out the on-board 8085A from ac- 
cessing the on-board memory. In this situation, 
memory commands from the 8085A and the controll- 
ing bus master are interleaved. This, of course will 
impose 8085A wait states while the controlling bus 
master’s memory command is being completed. 

Addresses for EPROM and 8085A access of on- 
board RAM are provided in table 3-1. Note that the 
EPROM address space depends on the users con- 


figuration. For Multibus access the on-board RAM 
may be mapped into any 4K, 8K or 16K segment 
within the addressing constraints of the controlling 
bus master. For 16-bit Multibus addressing, the on- 
board RAM may be mapped into any 4K, 8K or 16K 
segment of the 64K byte address space. For 20-bit 
Multibus addressing, the on-board RAM may be 
mapped into any 4K, 8K, or 16K segment of the 1 
megabyate address space. Ail memory must reside in 
the same 64K page. 

When the 8085A is addressing on-board memory 
(RAM or EPROM), RMACK/(RAM Acknowledge) 
or I0ACK/(I/0 Acknowledge) is automatically 
generated to prevent imposing an 8085A wait state. 
When the 8085A is addressing system memory (only 
if iSBC 544 is Bus Master) it generates a Memory 
Read or Memory Write Command and waits for a 
Transfer Acknowledge (XACK/) to be received from 
the addressed memory device. 

It should be noted in table 3-1 that it is possible to 
configure EPROM such as to create illegal addresses. 
If an illegal address is used in conjunction with a 
Memory Read Command to EPROM an lOACK/ 
(I/O Acknowledge) is generated as though the ad- 
dress was legal and the 8085A will continue executing 
the program. However, in this case, erroneous data 
will be returned. 

3-12. I/O ADDRESSING 

The on-board 8085A microprocessor communicates 
with the programmable chips through a sequence of 
I/O Read and I/O Write Commands, The I/O ad- 
dresses for the different chips are shown in table 3-2. 


Table 3-1 . iSBC 544 On-Board Memory Addresses 


Type 

Configuration 

Legal Address 

Illegal Address 

EPROM 

One 2716 chip 

0000 - 07FF 

0800 -OFFF 


Two 2716 chips 

0000 - OFFF 

- 

EPROM 

One 2732 chip 

0000 -OFFF 

1000-1FFF 


Two 2732 chips 

0000-1FFF 


RAM 

Eight 2117 chips 

*8000 - BFFF 

None 

Static RAM 

8155 chip 

*7F00 - 7FFF 

None 


•Default (factory connected) jumper. 
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Table 3-2. I/O Address Assignments 


I/O 

Address 

Chip 

Select 

Function 

DO 

8251 

USART 

0 

Write: Data {Port 0) 

Read: Data (Port 0) 

D1 

Write: Mode or Command (Port 0) 

Read : Status (Port 0) 

D2 

8251 

USART 

1 

Write: Data (Porti) 

Read: Data (Port 1) 

D3 

Write: Mode or Command (Port 1 ) 

Read Status (Porti) 

D4 

8251 

USART 

2 

Write: Data (Port 2) 

Read: Data (Port 2) 

D5 

Write: Mode or Command (Port 2) 

Read: Status (Port 2) 

D6 

8251 

USART 

3 

Write: Data (Port 3) 

Read: Data (Port 3) 

D7 

Write: Mode or Command (Port 3) 

Read; Status (Port 3) 

D8 


Write:CounterO (Load Count -i- N) 

Read: Counter 0 

D9 

8253 

PIT 

(#1) 

Write: Counter 1 (Load Count -r N) 

Read: Counter 1 

DA 

Write: Counter 2 (Load Count -r N) 

Read: Counter 2 

DB 


Write: Mode Word 

Read: None 

DC 


Write: Counter 3 (Load Count -j- N) 

Read: Counter 3 

DD 

8253 

PIT 

(#2) 

Write: Counter 4 (Load Count -i- N) 

Read: Counter 4 

DE 

Write: Counter 5 (Load Count -r N) 

Read; Counter 5 

DF 


Write: Mode Word 

Read: None 

E4 

MASTER 

MODE 

FLOP 

Set Master Mode 

E5 

Reset Master Mode 

E6 

8259 

Write: ICW1 , OCW2 and OCW3 

Read: Status and Poll 

E7 

PIC 

Write: ICW2, ICW3, and OCW1 (Mask) 

Read:OCW1 (Mask) 

E8 


Write: Load Command Register 

Read: Status 

E9 

8155 

Write: Port A 

Read: Port A 

EA 

PPI 

Write; Port B 

Read: Port B 

EB 


Write: Port C 

Read: PortC 

EC 


Write: Load LSB of Count Length 

Read: Read LSB of Count Length 

ED 

8155 

PPI 

Write: Load MSB + Mode Bits in Count Length 

Read: Read MSB + Mode Bits 

EE 

NOP 

EF 


NOP 
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3-13. 8253 PIT PROGRAMMING 

The basic clock frequency for the programmable 
chips is supplied by a 22.1 184-MHz crystal oscillator. 
This frequency is then divided by 12 and 18 to pro- 
duce two jumper selectable clocks: 1.8432 MHz and 
1.2288 MHz. These clocks are available for input to 
the counters on the 8253 PITs (Counters 0, 1, and 2 
on the first 8253, and Counters 3, 4, and 5 on the 2nd 
8253). The default (factory selected) and optional 
jumpers for selecting the clock inputs to the six 
counters are listed in table 2-3. The frequency of 
1.2288 MHz is selected for compatability with the 
iSBC 534. 


Default jumpers connect the outputs of the counters 
as shown in table 3-3. 

Before programming the 8253 PITs, ascertain the in- 
put clock frequency and the output function of each 
of the six counters. These factors are determined and 
established by the user during the installation. 

3-14. MODE CONTROL WORD COUNT 

All counters must be initialized separately prior to 
their use. The initialization for each counter consists 
of two steps: 

a. A mode control word (figure 3-4) is written to the 
control register for each individual counter. 


Table 3-3. 8253 PIT Counter Outputs 


Counter 

Output 

Fig 5-2 
Grid Ref 

Function 

Counter 0 

8ZC6 

BDGO - Supplies clock input for TXC and RXC of 8251 A USART 0. 

Counter 1 

8ZA6 

BDG1 - Supplies clock input for TXC and RXC of 8251 A USART 1. 

Counter 2 

9ZC6 

BDG2 - Supplies clock input for TXC and RXC of 8251 A USART 2. 

Counters 

9ZA6 

BDG3 - Supplies clock input for TXC and RXC of 8251 A USART 3. 

Counter 4 

7ZB1 

BDG4 - Supplies clock input to Counter 5 to produce a long time interval 
counter, or split receiver clocks for the USARTS. 

Counters 

7ZB1 

TINTI - Provides interval timer input to 8085A’s RST 7.5 restart function. 


D? 

DS 

DS 

D4 

03 

02 

01 

IB 




Q 

IQ 



(BINARY/BCD) 


0 

BINARY COUNTER (16-BITS) 

1 

BINARY CODED DECIMAL (BCD) COUNTER 
(4 DECADES) 


M2 M1 MO (MODE) 


0 

0 

0 

MODEO 

0 

0 

1 

MODE1 

X 

1 

0 

MODE 2 

X 

1 

1 

MODE 3 

1 

0 

0 

MODE 4 

1 

0 

1 

MODES 


■USE MODE 3 FOR 
BAUD RATE GENERATOR 


■USE MODE 4 FOR 


■ 


* INTERVAL TIMER 

RL1 

RLO 

(REAL/LOAD) 

0 

0 

COUNTER LATCHING OPERATION (REFER 

TO PARAGRAPH 4-14) 

1 

0 

READ/LOAD MOST SIGNIFICANT BYTE ONLY 

0 

1 

READ/LOAD LEAST SIGNIFICANT BYTE ONLY 

1 

1 

READ/LOAD LEAST SIGNIFICANT BYTE FIRST 
THEN MOST SIGNIFICANT BYTE 

SCI 

SCO 

(SELECT COUNTER) 

» 


SELECT COUNTER 0 

0 

1 

' SELECT COUNTER 1 

1 

0 

SELECT COUNTER 2 

1 

1 

ILLEGAL 


Figure 3-4. PIT Mode Control Word Format 
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b. A down-count number is loaded into each 
counter; number is in one or two 8-bit bytes as 
determined by mode control word. 

The mode control word (figure 3-4) does the follow- 
ing: 

a. Selects counter to be loaded. 

b. Selects counter operating mode (either Mode 3 or 
Mode 4 is recommended for the iSBC 544). 

c. Selects one of the following four counter 
read/load functions: 

( 1 ) Counter latch (f or stable read operation) . 

(2) Read or load most-significant byte only. 

(3) Read or load least-significant byte only. 

(4) Read or load least-significant byte first, then 
most-significant byte. 

d. Sets counter for either binary or BCD count. 

The mode control word and the count register bytes 
for any given counter must be entered in the follow- 
ing sequence: 

a. Mode control word. 

b. Least-significant count register byte. 

c. Most-significant count register byte. 

As long as the above procedure is followed for each 
counter, the chip can be programmed in any conve- 
nient sequence. For example, mode control words 
first can be loaded into each of three counters per 
chip, followed by the least significant byte, etc. 
Figure 3-5 shows the two programming sequences 
described above. 

Since all counters in the PIT chip are downcounters, 
the value loaded in the count registers is 
decremented. Loading ail zeroes into a count register 
results in a maximum count of 2'* for binary 
numbers or 10'* for BCD numbers. 

When a selected count register is to be loaded, it must 
be loaded with the number of bytes programmed in 
the mode control word. One or two bytes can be 
loaded, depending on the appropriate down count. 
These two bytes can be programmed at any time 
following the mode control word, as long as the cor- 
rect number of bytes is loaded in order. 

The count mode selected in the control word controls 
the counter output. As shown in figure 3-4, the PIT 
chip can operate in any of six modes; however, the 
iSBC 544 normally uses only Mode 3 and Mode 4 as 
follows: 

a. Mode 3: Square wave generator. Mode 3, which 
is the primary operating mode used in the iSBC 
544, is used for generating Baud rate clock 
signals. In this mode, the counter output remains 
high until one-half of the count value in the 
count register has been decremented (for even 


PROGRAMMING FORMAT 
Step 


1 

Mode Control Word 
Counter n 

2 

, CD Count Register Byte 
Counter n 

3 

Count Register Byte 
Counter n 


ALTERNATE PROGRAMMING FORMAT 
Step 


1 

Mode Controi Word 
Counter 0 

2 

Mode Controi Word 
Counter 1 

3 

Mode Control Word 
Counter 2 

4 

LSB 

Counter Register Byte 
Counter 1 

5 

MSB 

Count Register Byte 
Counter 1 

6 

LSB 

Count Register Byte 
Counter 2 

7 

MSB 

Count Register Byte 
Counter 2 

8 

LSB 

Count Register Byte 
Counter 0 

9 

MSB 

Count Register Byte 
Counter 0 


Figure 3-5. PIT Programming Sequence Examples 


numbers). The output then goes low for the other 
half of the count. If the value in the count 
register is odd, the counter output is high for (N 
-I- l)/2 counts, and low for (N -l)/2 counts. 

b. Mode 4: Software triggered strobe. After the 
mode is set, the output will be high. When the 
count is loaded, the counter will begin counting. 
On terminal count, the output will go low for one 
input clock period, then will go high again. If the 
count register is reloaded between output pulses 
the present period will not be affected, but the 
subsequent period will reflect the new value. 
Reloading the counter register will restart coun- 
ting beginning with the new number. 

NOTE 

Mode 4 can only be used on Counter 
5 (output = TINT1). 


3-15. ADDRESSING 

As listed in table 3-2, each PIT uses four consecutive 
I/O addresses (D8 through DB for PIT /I and DC 
through DF for PIT /2). The first three addresses for 
each PIT are used in loading and reading the count in 
the three counters on each chip. The fourth address 
on each chip is used in writing the mode control word 
to the desired counters. 


3-8 





iSBC 544 


Programming Information 


3-16. INITIALIZATION 

To initialize the PIT chips, peform the following: 

a. Write mode control word for PIT 0 Counter 0 to 
DB. Note that all mode control words for PIT 0 
are written to DB since mode control word must 
specify which counter is being programmed. 
(Refer to figure 3-4.) Table 3-4 provides a sample 
subroutine for writing mode control words to the 
six counters comprising PIT 0 and PIT 1 . 

b. Assuming mode control word has selected a 
2-byte load, load least-significant byte of count 
into Counter 0 at D8. (Count value to be loaded 
is described in paragraph 3-14.) Table 3-5 pro- 
vides a sample subroutine for loading 2-byte 
count value. 

c. Load most-significant byte of count into 
Counter 0 at D8. 

NOTE 

Be sure to enter the downcount in 
two bytes if the counter was pro- 
grammed for a two-byte entry in the 
mode control word. Similarly, enter 


the downcount value in BCD if the 
counter was so programmed. 

d. Repeat steps a, b, c and d for PIT 0 Counters 1 
and 2, and for PIT 1 counters as necessary. Refer 
to table 3-2 for I/O addresses. 

3-17. OPERATION 

The following paragraphs describe operating pro- 
cedures for a counter read, clock frequency 
divide/ratio selection, and interrupt timer count 
selection. 


3-18. COUNTER READ. For Mode 3 operation, 
there usually is no requirement to reset or read the 
counters; however, it is possible to do so at any time. 
If a count register is reloaded during counting in 
Mode 3, the new value is reflected immediately 
following the output transition of the current count. 
For Mode 4 (interrupt on terminal count), reloading 
during counting has the following results: 

a. Loading first byte stops current count. 


Table 3-4. Typical PIT Control Word Subroutine 


lINTTMR INITIALIZES INTERVAL TIMERS PIT 0 AND PIT 1 


;FOUR OF THE COUNTERS ARE INITIALIZED AS BAUD RATE GENERATORS. 

;THE OTHER TWO COUNTERS ARE SET UP AS INTERRUPT TIMERS. 
;ALL SIX COUNTERS ARE SET UP FOR 16-BIT BINARY OPERATION. 
;USES-NOTHING; DESTROYS-A 


PUBLIC 

INTTMR 


INTTMR: MVI 

A,36H 

;MODE 3 CONTROL WORD FOR COUNTERS 0 & 3 

OUT 

ODBH 


OUT 

ODFH 


MVI 

A,76H 

;MODE 3 CONTROL WORD FOR COUNTER 1 

OUT 

ODBH 


MVI 

A,0B6H 

;MODE 3 CONTROL WORD FOR COUNTER 2 

OUT 

ODBH 


MIV 

A,78H 

:MODE 4 CONTROL WORD FOR COUNTER 4 

OUT 

ODFH 


MIV 

A,0B8H 

;MODE 4 CONTROL WORD FOR COUNTER 5 

OUT 

ODFH 


RET 



END 




Table 3-5. Typical PIT Count Value Load Subroutine 
;LOADO LOADS COUNTER 0 FROM D & E. D IS MSB, E IS LSB. 


;USES D,E; DESTROYS-A 



PUBLIC 

LOADO 


LOADO: MOV 

A,E 

;GET LSB 

OUT 

0D8H 


MOV 

A,D 

;GETMSB 

OUT 

0D8H 


RET 



END 
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b. Loading second byte starts new count. 

If desired, it is possible to read the count register dur- 
ing the down count. The recommended procedure is 
to use a mode control word to latch the contents of 
the count register; this ensures that the count reading 
is accurate and stable. The latched value of the count 
can then be read by the main processor. 

NOTE 

If a counter is read during the down count, it 
is mandatory to complete the read pro- 
cedure; that is, if two bytes were programm- 
ed to the counter, then two bytes must be 
read before any other operations are per- 
formed with that counter. 

A typical Counter read subroutine is given in table 
3-6. 

a. Write counter register latch control word (figure 
3-6) to DB (PIT 0) or to DF (PIT 1), as ap- 
propriate. Control word specifies desired counter 
and selects counter latching operation. 

b. Perform a read operation of desired counter, 
refer to table 3-2 for counter addresses. 

NOTE 

Be sure to read one or two bytes, whichever was 
specified in the initialization mode control word. 
For two bytes, read in the order specified. 


3-19. CLOCK FREQUENCY/DIVIDE 
RATIO SELECTION 

The internal clock output-default jumper is con- 
nected so that the clock output frequency is 1.2288 
MHz. The jumper can be changed so that output fre- 
quency is 1.8432 MHz. (Refer to paragraph 2-15.) 
This clock signal is divided by the counters in the two 
PIT chips to generate signals BDGO through BDG5. 
The default wiring, in turn, connects signals BDGO 
through BDG3 to the USART transmit clock (TXC) 
and receive clock (RXC) inputs as shown in table 2-3. 

Each counter must be programmed with a down 
count number, of count value N. When count value 
N is loaded into a PIT counter, it becomes the clock 
divisor. To derive N for either synchronous or asyn- 
chronous operation, use the procedures described in 
the following paragraphs. 


3-20. SYNCHRONOUS MODE 

In the synchronous mode, the TXC and/or RXC 
rates equal the Baud rate. Therefore, the count value 
is determined by 

N = C/B 

where N is the count value, 

B is the desired Baud rate, and 
C is 1 .2288 MHz (or 1 .8432 MHz), the inter- 
nal clock freuqency. 


D7 D6 Ds D4 D3 D2 D-| Dq 


1 SC1 

SCO I 0 

0 I X I X 

* 

Z1 







SELECTS COUNI 

- DON'T CARE 

PER 


LATCHING OPERATION 

L SPECIFIES COUNTER TO BE LATCHED 
(SEE FIGURE 3-4) 

Figure 3-6. PIT Counter Register Latch 
Control Word Format 


Thus, for a 4800 Baud rate, the required count value 
(N) is: 


N = 


1.2288 X 10* 
4800 


= 256. 


If the binary equivalent of count value N = 256 is 
loaded into Counter 0 of PIT 0, then the output fre- 
quency of BDGO (for USART 0) is 4800 Hz, which is 
the desired clock rate for synchronous mode opera- 
tion. 


Table 3-6. Typical PIT Counter Read Subroutine 
;READ5 READS COUNTER 5 ON-THE-FLY INTO D & E. MSB IN D. LSB IN E. 


:USES NOTHING; DESTROYS-A,D,E 


PUBLIC 

READS 


READS: MVI 

A,80H 

;MOD£ WORD FOR LATCHING COUNTER S VALUE 

OUT 

ODFH 


IN 

ODEH 

;LSB OF COUNTER 

MOV 

E,A 


IN 

ODEH 

:MSB OF COUNTER 

MOV 

D,A 


RET 




END 
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3-21. ASYNCHRONOUS MODE. In the asyn- 
chronous mode, the TXC and/or RXC rates equal 
the Baud rate times of the following multipliers: XI, 
X16, or X64. Therefore, the count value is determin- 
ed by 

N = C/BM 

where N is the count value, 

B is the desired Baud rate, 

M is the Baud rate multiplier (1, 16, or 64), 
and 

C is 1 .2288 MHz (or 1 .8432 MHz), the inter- 
nal clock frequency. 

Thus, for a 4800 Baud rate, with a Baud rate 
multiplier of 16 the required count value (N) is 

_ 1.2288 xl0‘ _ 

4800x16 


Table 3-7. PIT Count Value Vs Rate Multiplier 
for Each Baud Rate 


Baud Rate 

(B) 

‘Count Value (N) FOR 

M = 1 

M = 16 

M = 64 

75 

16384 

1024 

256 

110 

11171 

698 

175 

150 

8192 

512 

128 

300 

4096 

256 

64 

600 

2048 

128 

32 

1200 

1024 

64 

16 

2400 

512 

32 

8 

4800 

256 

16 

4 

9600 

128 

8 

2 

19200 

64 

4 


38400 

32 

2 



‘Count Values (N) assume clock is 1.2288 MHz. 
Multiply Count Values (N) by 1.5 for 1.8432 MHz. 
Count Values (N) and Rate Multipliers (M) are in 
decimal. 


If the binary equivalent of count value N = 16 is load- 
ed into Counter 1 of PIT 0, then the output frequen- 
cy of BDGl (for USART 1) is 4800 x 16 Hz, which is 
the desired clock rate for asynchronous mode opera- 
tion. Count values (N) versus rate multiplier (M) for 
each Baud rate are listed in table 3-7. 

NOTE 

During initialization, be sure to load the 
count value (N) into the appropriate PIT 
counter and the Baud rate multiplier (M) in- 
to the USART. 


3-22. RATE GENERATOR/ 

INTERVAL TIMER 

Table 3-8 shows the maximum and minimum timer 
intervals when Counters 4 and 5 of PIT 1 are con- 
nected in parallel or series. These counters generate 
signals BDG4 and TINTl, which can be used either 
as auxiliary clock counters or to generate interrupt 
intervals. 


3-23. INTERRUPT TIMER 

To program an interval timer for an interrupt on ter- 
minal count, program the appropriate PIT for the 
correct operating mode (Mode 4) in the control word. 
Then load the count value (N), which is derived by 

N=TC 

where N is the timer count value 

T is the desired interrupt time interval in 
seconds, and 

C is the internal clock frequency (Hz). 

Table 3-9 shows the count value (N) required for 
several time intervals (T) that can be generated for 
outputs BDG4 and TINTl . 


Table 3-8. PIT Rate Generator Frequencies and Timer Intervals 


Function 

Single Timer* 

(BDGOThru 

BDG4 -i- TINTl) 

Dual Timer* 

(BDG4and TINTl 

In Series) 

Single Timer^ 

(BDGOThru 

BDG4 + TINTl) 

Dual Timer^ 

(BDG4and TINTl 

In Series) 

Minimum Maximum 

Minimum Maximum 

Minimum Maximum 

Minimum Maximum 

Rate 

Generator 

(Frequency) 

18.75 Hz 614.4 kHz 

0.00029 Hz 307.2 kHz 

28.125 Hz 921.6 Hz 

.00044 Hz 460.8 KHz 

Real-Time 

Interrupt 

(Interval) 

1.63fisec 53.3 msec 

3.26 fisec 

minutes 

1.09 /isec 35.5 msec 

0 17 38.83 

2.17 usec 

minutes 

Notes: 

1. Assuming a 1.2288 MHz clock input. 

2. Assuming a 1.8432 MHz clock input. 
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Table 3-9. PIT Time Intervals Vs Timer Counts 


T 

N* 

10 fisec 

12 

100 jisec 

123 

1 msec 

1229 

10 msec 

12288 

50 msec 

61440 

* Count Values (N) assume clock is 1.2288 MHz. For 

1.8432 MHz multiply Count Value (N) by 1.5. Count 

values (N) are in decimal. 


3-24. 8259 PIC PROGRAMMING 

The 8259 Programmable Interrupt Controller (PIC) 
performs the function of an interrupt manager on the 
iSBC 544. It monitors the interrupt requests from 
eight separate sources. When one or more of the in- 
terrupt requests are active (true), the PIC determines 
the following: 

a. Which input signal has the highest priority. 

b. Whether the input signal has a higher priority 
than the interrupt presently being serviced by the 
processor. If so, the interrupt being serviced is 
interrupted; if not, the input signal is held for 
later output. 

c. Whether the interrupt input bit is masked. 

Thus the basic functions of the PIC are (1) to resolve 
the priority of interrupt requests and (2) issue a single 
interrupt request to the on-board 8085A based on the 
priority. The output of the 8259 PIC is applied 
directly to the INTR input at the 8085A 
microprocessor. (Refer to paragraph 2-14.) 


3-25. INTERRUPT PRIORITY MODES 

The PIC has two modes for resolving the priority of 
interrupt inputs: (1) fully nested mode and (2) 
rotating mode. The rotating mode has two varia- 
tions: (1) auto-rotating and specific rotating. 


3-26. FULLY NESTED MODE. In this mode the 
PIC input signals are assigned priority from 0 
through 7. The PIC operates in this mode unless 
specifically programmed otherwise. Interrupt IRO 
has the highest priority, IR7 has the lowest priority. 
When an interrupt is acknowledged, the highest 
priority request is available to the 8085 A. Lower 
priority interrupts are inhibited; higher priority inter- 
rupts will be able to generate an interrupt that will be 
acknowledged if the 8085A has enabled its own inter- 
rupt input through its software. The End-Of-Inter- 
rupt (EOI) command from the 8085A is required to 
reset the PIC for the next interrupt. 


3-27. AUTO-ROTATING MODE. In this mode 
the interrupt priority rotates. Once an interrupt on a 
given input is serviced, that interrupt assumes the 
lowest priority. Thus, if there are a number of 
simultaneous interrupts, the priority will rotate 
among the interrupts in numerical order. For exam- 
ple, if interrupts IR4 and IR6 request service 
simultaneously, IR4 will receive the highest priority. 
After service, the priority level rotates so that IR4 has 
the lowest priority and IR5 assumes the highest 
priority. In the worst case, seven other interrupts are 
serviced before IR4 again has the highest priority. Of 
course, if IR4 is the only request, it is serviced pro- 
mptly. In the Auto-Rotating Mode, priority shifts 
when the PIC chip receives an EOI command. 


3-28. SPECIFIC ROTATING MODE. In this 
mode the software can change interrupt priority by 
specifying the bottom priority, which automatically 
sets the highest priority. For example, if IR5 is 
assigned the bottom priority, IR6 assumes the highest 
priority. In the specific rotating mode, the priority 
can be rotated by writing a Specific Rotate at EOI 
(SEOI) command to the PIC chip. This command 
contains the BCD code of the interrupt being servic- 
ed; that interrupt is reset as the bottom priority. In 
addition, the bottom priority interrupt can be fixed 
at any time by writing a command word to the PIC 
chip. 


3-29. INTERRUPT MASK 

One or more of the eight interrupt request inputs can 
be individually masked during the PIC initialization 
or at any subsequent time. If an interrupt is masked 
while it is being serviced, lower priority interrupts are 
inhibited. There are two ways to enable the lower 
priority interrupts: 

a. Write an End-of-Interrupt (EOI) command. 

b. Set the Special Mask Mode. 

The Special Mask Mode is useful when one or more 
interrupts are masked. If for any reason an input is 
masked while it is being serviced, the lower priority 
interrupts are disabled. However, it is possible to 
enable the lower priority interrupt with the Special 
Mask Mode. In this mode, the lower priority lines are 
enabled until the Special Mask Mode is reset. Higher 
priorities are not affected. 

3-30. STATUS READ 

Interrupt request inputs are handled by the following 
two internal PIC registers: 

a. Interrupt Request Register (IRR), which stores 
all interrupt levels that are requesting service. 
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b. In-Service Register (ISR), which stores all 
interrupt levels that are being serviced. 

Either register can be read by writing a suitable com- 
mand word and then performing a read operation. 


3-31 . INITIALIZATION COMMAND 
WORDS 

The eight interrupt service routines that are called by 
the PIC have eight addresses equally spaced in 
memory that can be programmed at intervals of four 
or eight bytes (see tables 3-28). Interrupt service 
routines thus occupy a 32 or 64-byte block respective- 
ly, of memory. The address format for device inter- 
rupt service routines is shown in figure 3-7. 



Initialization of the 8259 PIC consists of writing two 
or three 8-bit Initialization Command Words as 
shown in figure 3-8. Since there are no slave PICs, 
the initialization for the one PIC consists of writing 
two Initialization Command Words as follows: 

a. The first Initialization Command Word (ICWl) 
consists of the following: 

1) Bits 5-7 specify the most-significant bits of 
the lower address byte of the interrupt ser- 
vice routine. 

2) Bit 2 specifies the address interval. 

3) Bit 3 specifies whether or not there are slave 
(cascaded) PICs. Since there are no slave 
PICs, set bit 1 = 1. 

4) Bits 0, 3, and 4 identify the word as an 
ICWl. 

b. The second word (ICW2) specifies the 
upper-byte (bits 8-15) of the interrupt service 
routine. 


3-32. OPERATION COMMAND WORDS 

After being initialized, the PIC can be programmed 
at any time for various interrupt modes. The Opera- 
tion Command Word (OCW) formats are shown in 
figure 3-9 and discussed in paragraph 3-35. 


Figure 3-7. PIC Interrupt Routine Addresses 

Bits 0-4 are automatically inserted by the 8259, while 
bits 6-15 are programmed by Initialization Command 
Words ICWl and ICW2. Bit 5 is dependent on the 
address interval. If the interval is eight bits, bit 5 is 
automatically inserted by the PIC. If the interval is 
four bits, bit 5 is programmed in ICWl. Therefore, 
the 32 byte or 64 byte block of addresses reserved for 
interrupt service routines can be located anywhere in 
the available memory space. Table 3-10 shows the ad- 
dress format inserted by the PIC for each device. 


3-33. ADDRESSING 

The PIC uses two consecutive addresses for writing 
to and reading internal registers. Address functions 
pertinent to programming are identified in table 3-2. 

3-34. INITIALIZATION 

To initialize the PIC proceed as follows (table 3-11 
provides a typical initialization subroutine): 

a. Disable system interrupts by executing a DI 
(Disable Interrupts) instruction. 


Table 3-10. PIC Device Address Insertion 


Lower Routine Address Byte 


Interval = 4 


Interval = 8 


Lower Memory Routine Address 



D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

D7 

D6 

D5 

D4 

D3 

D2 

D1 

DO 

A7 

A6 

A5 

1 

1 

1 

0 

0 

A7 

A6 

1 

1 

1 

0 

0 

0 

A7 

A6 

A5 

1 

1 

0 

0 

0 

A7 

A6 

1 

1 

0 

0 

0 

0 

A7 

A6 

A5 

1 

0 

1 

0 

0 

A7 

A6 

1 

0 

1 

0 

0 

0 

A7 

A6 

A5 

1 

0 

0 

0 

0 

A7 

A6 

1 

0 

0 

0 

0 

0 

A7 

A6 

A5 

0 

1 

1 

0 

0 

A7 

A6 

0 

1 

1 

0 

0 

0 

A7 

A6 

A5 

0 

1 

0 

0 

0 

A7 

A6 

0 

1 

0 

0 

0 

0 

A7 

A6 

A5 

0 

0 

1 

0 

0 

A7 

A6 

0 

0 

1 

0 

0 

0 

A7 

A6 

A5 

0 

0 

0 

0 

0 

A7 

A6 

0 

0 

0 

0 

0 

0 
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Dj De Ds D4 D3 D2 Di Do 




D7 Do D5 D4 D3 D2 Di Do 



Figure 3-8. PIC Initialization Command Word Formats 
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O7 Dg Og 04 O3 O2 Dg 



OCW 2 

D7 Og Dg D4 Dg Dg O') Dg 


IS 


D 

D 

B 

□1 





BCD LEVEL TO BE RESET 
OR PUT INTO LOWEST PRIORITY 


□ 

D 

D 

D 

D 

B 

□ 

D 

□ 

D 

□ 

D 

□ 

D 

□ 

D 

□ 

□ 

D 

n 

D 

□ 

D 

dI 

□ 

□ 

□ 

□ 

n 

D 

D 

D 


OCW 3 

D? Dg Og Dg D3 Dg Dg Dg 



Figure 3-9. PIC Operation Control Word Formats 


3-15 















Programming Information 


iSBC 544 


b. Write ICWl to E6. 

c. Write ICW2 to E7. 

d. Enable system interrupts by executing an El 
(Enable Interrupts) instruction. 

NOTE 

The PIC chip operates in the fully 
nested mode after the initialization 
sequence without requiring any 
Operation Control Word (OCW), 
however the mask register must be 
properly initialized. 

3-35. OPERATION 

After initialization, the PIC can be programmed at 
any time for the following operations: 

a. Auto-rotating priority. 

b. Specific rotating priority. 

c. Status read of Interrupt Request Register (IRR). 


d. Status read of In-Service Register (ISR). 

e. Interrupt mask bits set, reset, or read. 

f . Special mask mode set or reset. 

Table 3-12 lists the details of the PIC programming 
operations. Note that an End-Of-Interrupt (EOI) or 
a Special-End-Of-Interrupt (SEOI) command is re- 
quired at the end of each interrupt service routine to 
reset the ISR. The EOI command is used in the fully 
nested, polled, and auto-rotating priority modes and 
the SEOI command, which specifies the bit to be 
reset, is used in the specific rotating priority mode. 
Table 3-13 through 3-17 provide typical subroutines 
for the following: 

a. Read IRR (table 3-1 3) 

b. Read ISR (table 3-14) 

c . Set mask register (table 3-15) 

d. Read mask register (table 3-16) 

e. Issue EOI command (table 3-17) 


Table 3-11. Typical PIC Initialization Subroutine 


;INT59 INITIALIZES THE INTERRUPT CONTROLLER ON THE SBC-544. 
iSTANDARD VECTORED INTERRUPTS ARE USED WITH AN 8-BYTE SPACING. 

;IR0 VECTORS TO 40H, IR7 VECTORS TO 78H.ALL INTERRUPTS ARE MASKED 
;BY THIS ROUTINE AND INTERRUPTS ARE DISABLED. 

;USES-NOTHING 

DESTROYS-A 


PUBLIC 

INT59 


EXTRN 

BASAD 


INT59: Dl 


; DISABLE INTERRUPTS 

MVI 

A,01010010B 

: ICWIC INSTRUCTION 

OUT 

0E6H 


MVI 

A,0 

: ICW2 

OUT 

0E7H 


MVI 

A.OFFH 

; MASK ALL INTERRUPTS 

OUT 

0E7H 


RET 



END 




Table 3-12. PIC Operation Procedures 


Operation 

Procedure 

Auto-Rotating 

To set: 

Priority Mode 

In OCW2, write a rotate Priority at EOi command (AOH) to E6. 

Terminate interrupt and rotate priority: 

In OCW2, write EOi command (20H) to E6. 

Specific Rotating 

To set: 

Priority Mode 

In OCW2, write a Rotate Priority at SEOI command in the following format to E6: 

|D7 I D6 I D5 I D4 1 D3 1 D2 I D1 I DO I 

1 1 1 0 0 L2 LI LO 

BCD OF IR LINE TO BE RESET 

AND/OR PUT INTO LOWEST 

PRIORITY. 
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Table 3-12. PIC Operation Procedures (Cont’d.) 


Operation 



Interrupt Request 
Register (IRR) 
Status 


Procedure 


To terminate interrupt and rotate priority: 
in OCW2, write an SEOI command in the following format to E6: 

[d7|D6|D5|D4|D3|D2|d1 |do| 

0 1 1 0 0 L2 LI LO 


BCD OF ISR FLIP-FLOP TO BE 
RESET. 


To rotate priority without EOl: 

In OCW2, write a command word in the following format to E6: 




BCD OF BOTTOM PRIORITY IR 
LINE. 


The IRR stores a “1” in the associated bit for each IR input line that is requesting 
an interrupt. To read the IRR (refer to footnote): 

(1) Write OAH to E6. 

(2) Read E6. Status Format is: 

[d |D6|D5|D4|D3|D2|D1 |do| 

IR LINE: 7 6 5 4 3 2 1 0 


In-Service 
Register (ISR) 
Status 


The ISR stores a “1” in the associated bit for priority inputs that are being 
serviced. The ISR is updated when an EOl command is issued. To read the ISR 
(refer to footnote): 

(1) Write OBH to E6. 

(2) Read E6. Status format is: 


D7 D6 D5 D4 D3 D2 D1 DO 


IR LINE: 7 6 


Be sure to reset ISR bit at end-of-interrupt when in the following modes: 
Auto-Rotating (both types) and Special Mask. To reset ISR in OCW2, write: 




0 110 0 L2 LI LO 

BCD IDENTIFIES BIT TO BE 
RESET. 


Interrupt Mask 
Register 


To set mask bits in OCW1 , write the following mask byte to E7: 


I D7 I D6 I D5 1 D4 1 D3 1 D2 1 D1 I DO I 
IR BIT MASK: M7 M6 M5 M4 M3 M2 Ml MO 
1 = MASK SET, 0 = MASK RESET 


To read mask bits, read E7. 


Special Mask 
Mode 


The Special Mask Mode enables desired bits that have been previously masked; 
lower priority bits are also enabled. 


To set, write 68H to E6. 


To reset, write 48H to E6. 


If previous operation was addressed to same register, it is not necessary to rewrite the OCW. 
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Table 3-13. Typical PIC Interrupt Request Register Read Subroutine 


;RR0 READS INTERRUPT REQUEST REG 
:USES-NOTHING; DESTROYS-A 


PUBLIC 

RRO 


RRO; MVI 

OUT 

IN 

RET 

A.OAH 

0E6H 

0E6H 

;OCW3 RR INSTRUCTION TO PIC 

END 




Table 3-14. Typical PIC In-Service Register Read Subroutine 


;RIS READS IN-SERVICE REGISTER OF PIC 
;USES-NOTHING; DESTROYS-A 


PUBLIC 

RISC 


RIS: MVI 

OUT 

IN 

RET 

A.OBH 

0E6H 

0E6H 

;OCW3 RIS INSTRUCTION TO PIC 

END 




Table 3-15. 

Typical PIC Set Mask Register Subroutine 

;SMASK STORES A REG INTO MASK REG OF PIC 

;A ONE MASKS OUT AN INTERRUPT, A ZERO ENABLES IT 

:USES-A; DESTROYS-NOTHING 


PUBLIC 

SMASK 

SMASK 

OUT 

RET 

0E7H 


END 



Table 3-16. Typical PIC Mask Register Read Subroutine 


;RMASK READS MASK REG OF PIC INTO A REG 

,USES-NOTHING; DESTROYS-A 


PUBLIC 

RMASK 

RMASK: IN 

0E7H 

RET 


END 
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Table 3-17. Typical PIC End-of-Interrupt Command Subroutine 


;EOI ISSUES END-OF-INTERRUPT TO PIC 
;USES-NOTHING; DESTROYS-A 


PUBLIC 

EOl 


EOlO: MVI 

OUT 

RET 

A,20H 

0E6H 

;NON-SPECIFIC EOl 

END 




3-36. 8155 PROGRAMMABLE 
PERIPHERAL INTERFACE 
AND TIMER 

The Intel 8155 is made up of the following opera- 
tional areas: 

a. 256 X 8 Static RAM. 

b. 14 bit Timer. 

c. Two 8-bit I/O ports (one input and one output) 
and one 6-bit I/O input port. 

3-37. 8155 I/O PORT PROGRAMMING 

The parallel I/O port, which is controlled by the Intel 
8155 PPI chip, is designed to interface directly with a 
Bell Model 801 Automatic Calling Unit (ACU). The 
PPI chip has two 8 bit parallel ports (Port A which is 
an output port, and Port B which is an input port) 
and a 6-bit parallel input port (Port C). The follow- 
ing table is a list of the signals interfaced to the PPI 
chip. 


Port A Outputs 

Port B Inputs 

Port C Inputs 

NB1 orSTXDO 
NB2orSTXD1 

NB4 orSTXD2 
NB8orSTXD3 

PGRST (For 8251 
USARTS) 

RIO (Port 0) 

RI1 (Porti) 

RI2 (Port 2) 

RI3 (Port 3) 
CDO(PortO) 

PNDorSRXDO 
COSorSRXDI 
DLO or SRXD2 
ACRorSRXD3 
PINT 

Reset for INT FLOPS 
CRQ 

DPR 

CD1 (Porti) 
CD2(Port2) 
CD3(Port3) 

PFS 

NOTES 



1 . Rl and CD signals are connected to interrupt circuit. 

2. Rl and CD are from serial I/O ports. 


3-38. ADDRESSING OF I/O PORTS. The I/O 

section of the 8155 consists of a Command/Status 
Register (C/S) and one register for each of the three 
I/O ports. Addresses for these four registers are pro- 
vided in table 3-2. 


3-39. INITIALIZATION. The 8155 is reset when 
power is initially applied to the system. However an 
initialize routine must be generated for the 8155 in 
order to set up the ACU interface, and to remove the 
reset condition from the USARTS and from the 
RINT and PINT interrupt flops. Table 3-18 is a 
typical initialize routine. 


3-40. COMMAND REGISTER FORMAT. The 

Command Register consists of eight 1-bit latches. 
Bits 0-3 define the mode of Port A, B, and C, bits 4 
and 5 enable or disable Port A and B interrupts, and 
bits 6 and 7 are used for the Timer portion of the 
8155. Figure 3-10 shows the Command Register for- 
mat. 

The Command Register can be altered at any time by 
performing an I/O write command to port E8. Table 
3-19 is a typical Command Register Load routine. 


3-41. STATUS REGISTER FORMAT. The Sta- 
tus Register consists of seven 1-bit latches. Bit 0-5 
define the status of the ports, and bit 6 defines the 
status of the timer. The Status Register format is 
shown in figure 3-11. 


The contents of the Status Register can be obtained 
at any time by performing an I/O read to port E8. 
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DEFINES PORT A 


DEFINES PORT B 


DEFINES PORT C 


ENABLE PORT A 
INTERRUPT 
ENABLE PORT B 
INTERRUPT 


00 = NOP — DO NOT AFFECT COUNTER 

OPERATION 

01 = STOP - NOP IF TIMER HAS NOT 

STARTED: STOP COUNTING IF 
TIMER IS RUNNING 

10 = STOP AFTER TC - STOP 

IMMEDIATELY AFTER PRESENT TC 
IS REACHED (NOP IF TIMER HAS 
NOT STARTED) 

11 = START - LOAD MODE AND CNT 

LENGTH AND START IMMEDIATELY 
AFTER LOADING (IF TIMER IS NOT 
PRESENTLY RUNNING). IF TIMER 
IS RUNNING, START THE NEW 
MODE AND CNT LENGTH 
IMMEDIATELY AFTER PRESENT TC 
IS REACHED. 


0 = INPUT 

1 = OUTPUT 


( 00 = ALT1 
11 = ALT2 
01 = ALT3 
10 = ALT4 


1 = ENABLE 
0 = DISABLE 


Figure 3-10. Command Register Format 


Table 3-18. Typical 8155 Initialize Routine 


:INTAUX INITIALIZES THE 8155 PARALLEL I/O 
:PORT CHIP. THE DATA IN REG C IS PUT OUT 
;ON PORT A. THE TIMER IS STOPPED. 



PUBLIC 

INTAUX 


INTAUX: 

MVI 

A,41H 

;PORT A OUT; PORTS B + C 
IN; STOP TIMER 


OUT 

0E8H 



MOV 

A,C 

;GET PORT A DATA 


OUT 

0E9H 



RET 




END 




NOTE 

Register C must be loaded with the correct bit configuration to set up the ACU interface and to reset the 
USARTS, and the Ring Indicator and Carrier Detect Interrupt flops. A typical bit configuration would 
be COH, 
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Table 3-19. Typical Command Register Load Routine 


:INTAUX INITIALIZES THE 8155 PARALLEL I/O PORT CHIP. THE DATA IN REG 

;C IS PUT OUT ON PORT A. THE TIMER IS STOPPED. 


PUBLIC 

INTAUX 


EXTRN 

BASAD 


INTAUX; MVI 

A,41H 

;PORT A OUT; PORTS B&C IN; STOP TIMER 

OUT 

E8H 


MOV 

A,C 

;GET PORT A DATA 

OUT 

E9H 


RET 



END 




AD? ADe AOs AD4 AD3 AD2 AO1 ADq 



TIMER 

INTE 

B 

B 

BF 

INTR 

B 

INTE 

A 

A 

BF 

INTR 

A 




PORT A INTERRUPT REQUEST 
PORT A BUFFER FULUEMPTY 
(INPUT/OUTPUT) 

PORT A INTERRUPT ENABLE 
PORT B INTERRUPT REQUEST 
PORT B BUFFER FULUEMPTY 
(INPUT/OUTPUT) 

PORT B INTERRUPT ENABLED 

TIMER INTERRUPT (THIS BIT 

IS LATCHED HIGH WHEN TERMINAL COUNT IS 

REACHED, AND IS RESET TO 

LOW UPON READING OF THE 

CIS REGISTER OR STARTING 

NEW COUNT.) 


Figure 3-11. Status Register Format 


3-42. PORT A PROGRAMMING 

Port A is an output port, and is written to by the 
CPU. Data is written to Port A, or a call is placed 
with the ACU, by performing a write to E9. 

The status of the previous bits written to Port A can 
be obtained by performing a read to E9. 

Figure 3-12 shows the bit definitions for Port A. 

3-43. PORTS AND C PROGRAMMING 

Data from Port B and Port C is read by performing a 
read of EA and EB, respectively. Bit definitions for 
Ports B and C are given in figure 3-13. 

Typical routines for programming Ports A, B, and C 
are shown in table 3-20. 


3-44. 8155 TIMER PROGRAMMING 

The 8155 Timer is a 14-bit down counter that counts 
the timer input pulses (1 .2288 MHz) and provides an 
output of a square wave or pulse when terminal 
count (TC) is reached. The timer output (TINTO) is 
connected by a jumper to the RST 7.5 inut on the on- 
board 8085 A CPU. By connecting the timer output 
to the RST 7,5 input of the CPU, the CPU can be in- 
terrupt driven at an interval desired for serial I/O 
communications. The count lengths required for 
various baud rates are given in table 3-21 . 


3-45. ADDRESSING. The 8155 Timer has two 
I/O addresses associated with it. One address (EC) is 
for the low order byte (least-significant bits of count 
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PORTA 




D7 

D6 

D5 

04 

03 

02 

0l 

00 

CRQ 

DPR 

□ 

UR 

NB8 

NB4 

NB2 

NB1 


r 


NUMBER BIT NB1 (LSR): 1 = TRUE 

NUMBER BIT NB2: 1 = TRUE 

NUMBBI BIT NB4: 1 = TRUE 

NUMBER BIT NB8 (MSB): 1 = TRUE 

USART RESET: 1 = TRUE 

INTERRUPT RESET: 1 = TRUE 

DIGiT PR^ENT ON NUMBER BIT LINES: 0 = TRUE 

CALL REQUEST: 0 = TRUE 


Figure 3-12. PPI Port A Bit Definitions 


Table 3-20. Typical I/O Port Programming Routines 

;AOUT OUTPUTS THE DATA IN REG C TO PORT A OF THE 8155. 
;USES-C DESTROYS-A 

PUBLIC AOUT 

AOUT: MOV A,C ;GETDATA 

OUT 0E9H 

RET 

END 


;AIN READS PORT A OF THE 8155 INTO REG A. 
;USES-NOTHING DESTROYS-A 



PUBLIC 

AIN 

AIN: 

IN 

0E9H 


RET 



END 



;BIN READS PORT B OF THE 8155 INTO REG A. 
;USES-NOTHING DESTROYS-A 



PUBLIC 

BIN 

BIN: 

IN 

OEAH 


RET 



END 



;CIN READS PORT C OF THE 8155 INTO REG A. 
;USES-NOTHING DESTROYS-A. 


PUBLIC 

CIN 

EXTRN 

BASAD 

IN 

OEBH 

RET 


END 
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PORTC 



PRESENT NEXT DIGIT: 0 = TRUE 

CALL COMPLETE, LINE TRANSFERRED TO MODEM: 

0 = TRUE 

DATA LINE OCCUPIED: 0 = TRUE 
ABANDON CALL & RETRY: 0 = TRUE 
FLAG INTERRUPT: 1 = TRUE 
POWER FAIL SENSED: 1 = TRUE 


PORT B 



RING INDICATOR, PORT 0: 0 = TRUE 
RING INDICATOR, PORT 1:0 = TRUE 
RING INDICATOR, PORT 2: 0 = TRUE 
RING INDICATOR, PORT 3: 0 = TRUE 
CARRIER DETECT, PORT 0: 0 = TRUE 
CARRIER DETECT, PORT 1: 0 = TRUE 
CARRIER DETECT, PORT 2: 0 = TRUE 
CARRIER DETECT, PORT 3: 0 = TRUE 


Figure 3-13. Port B and C Bit Definitions 


length), and the other address (ED) is for the high 
order byte (most-significant bits of count length and 
timer mode). Figure 3-14 shows the timer format. 


VO 

ADDRESS 
EC 

LSB OF CNT LENGTH 


0 

t6 



t3 

0 

0 



3-46. COUNT LENGTH REGISTER LOADING 
AND READING. The timers I/O addresses serve a 
dual purpose. During an I/O Write operation, the 
count length (bits 0-13) and mode (bits 14-15) are 
loaded into the 16 bit Count Length Register; during 
an I/O Read operation, the present count (the count 
at the time of the I/O Read operation) and the mode 
bits are read. To ensure that the correct count is read, 
it is preferable to stop counting, read the counter, 
and then reload the counter and continue counting. 


Table 3-21 . Baud Rates Vs Count Lengths 


Baud Rate 

Decimal Count 

4800 

256 

2400 

512 

1200 

1024 

600 

2048 

110 

11171 

75 

16384 


M2 

M1 

f13 

‘12 

til 

tio 

<9 

t8 


T — r 


IK> 

ADDRESS 

ED 


TIMER MSB OF 
MODE CNT LENGTH 


M2M1 

0 0 OUTPUT LOW DURING 

SECOND HALF OF COUNT. 
(SEE NOTE) 


0 1 SQUARE WAVE OUTPUT; i.e., 
THE PERIOD OF THE 
SQUARE WAVE EQUALS THE 
COUNT LENGTH 
PROGRAMMED WITH 
AUTOMATIC RELOAD AT 
TERMINAL COUNT. 


1 0 SINGLE PULSE OUTPUT 

UPON TC BEING REACHED. 


1 1 AUTOMATIC RELOAD; U., 
SINGLE PULSE OUTPUT 
EVERY TIME TC IS 
REACHED. 


NOTE: In case of an asymmetric count 
(e.g., 15), output will be high 
during larger half of count. 


Figure 3-14. Timer Format 
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3-47. 8155 TIMER OPERATION. To program 
the timer, first stop the counter, then load the Count 
Length Register, one byte at a time, by performing 
I/O Write routines to the two timer addresses (EC 
and ED). Bits 0-13 will specify the length of the next 
count, and bits 14-15 will specify the timer output 
mode. There are two modes to choose from on the 
iSBC 544: 

1 . Single pulse upon TC being reached . 

2. Repetitive single pulses each time TC is reached 
and automatic reload of counter when TC is 
reached, until instructed to stop by a new com- 
mand loaded into the Command/Status 
Register. 

Bits 6-7 of the Command/Status Register are used to 
start and stop the counter. See Figure 3-10 for a 
description of the different commands. 

Table 3-22 shows a typical 8155 Timer load and 
count routine. 


3-48. 8251AUSART PROGRAMMING 

Each of the four serial I/O ports is controlled by an 
Intel 8251 A US ART chip. The US ART converts 
parallel output data into virtually any serial output 
data format (including IBM Bi-Sync) for half- or 
full-duplex operation. The USART also converts 
serial input data into parallel data format. 


Prior to starting transmitting or receiving data, the 
USART must be loaded with a set of control words. 
These control words, which define the complete 
functional operation of the USART, must im- 
mediately follow a reset (internal or external) opera- 
tion. The control words are either a Mode instruction 
or a Command instruction. 


3-49. MODE INSTRUCTION FORMAT 

The Mode instruction word defines the general 
characteristics of the USART and must follow a reset 
operation (internal or external). Once the Mode in- 
struction word has been written into the USART, 
sync characters or command instructions may be in- 
serted. The Mode instruction word defines the 
following: 

a. For Sync Mode: 

(1) Character length 

(2) Parity enable 

(3) Even/odd parity generation and check 

(4) External sync detect (not supported by iSBC 
544) 

(5) Single or double character sync 

b. For Async Mode: 

(1) Baud rate factor (XI, XI 6, or X64) 

(2) Character length 

(3) Parity enable 

(4) Even/odd parity generation and check 

(5) Number of stop bits 

Instruction word and data transmission formats for 
synchronous and asynchronous modes are shown in 
figures 3-15 through 3-18. 


Table 3-22. Typical 8155 Timer Routine 


MAIN PROGRAM - INITIALIZES THE 8155 COUNTER AND STARTS THE 
COUNT BEFORE CONTINUING WITH ITS OTHER ROUTINES. THIS PROGRAM 
SETS THE TIME TO COUNT 122 TIMER-IN PULSES BEFORE OUT- 
PUTTING A TIMER PULSE THAT WILL GENERATE AN INTERRUPT. 

USING MODE 3, THE TIMER WILL AUTOMATICALLY RELOAD 
AND BEGIN ANOTHER COUNTDOWN. 


MVI 

A,7CH 


OUT 

OECH 

; OUTPUT LSB OF COUNT LENGTH 

MVI 

A.OCOH 


OUT 

OEDH 

; OUTPUT MSB AND TIMER MODE 

MVI 

A,18H 


SIM 


; UNMASK RESTART INTERRUPTS 

El 


; ENABLE PROCESSOR INTERRUPTS 

MVI 

A.OCOH 


OUT 

0E8H 

; START TIMER COUNTDOWN 


MAIN PROGRAM CONTINUES 


END MAIN PROGRAM 
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O7 D@ Ds D4 D3 O2 D-) Dq 



D7 ^6 D5 D4 D3 D2 Di Dq 



Figure 3-15. Synchronous Mode Instruction 
Word Format 


Figure 3-17. Asynchronous Mode Instruction 
Word Format 


CPU BYTES (5-8 BITS/CHAR) 




DATA CHARACTERS 


1 

I • 

ASSEMBLED SERIAL DATA OUTPUT (TxD) 

SYNC 

CHAR1 

SYNC 
CHAR 2 

DATA CHARACTERS 

(t 


RECEIVE FORMAT 


SERIAL DATA INPUT (RxD) 


TRANSMITTER OUTPUT 



P ' if 


—i 1 

MARKING I 

DATA BITS 

if 

PARITY 

BIT 

STOP 1 

BITS 1 


RECEIVER INPUT 




P // 



RxD 

START 

BIT 

DATA BITS 



PARITY 

BIT 

STOP 1 

BITS 1 


TRANSMISSION FORMAT 

CPU BYTE (5-8 BITS/CHAR) 



DATA CHARACTER 

(( 

ASSEMBLED SERIAL DATA OUTPUT (TxD) 









SYNC 

CHARI 

SYNC 
CHAR 2 


1 START 

1 BIT 


PARITY 

BIT 



CPU BYTES (5-8 BITS/CHAR) 

IV— — 


RECEIVE FORMAT 


DATA CHARACTERS 




SERIAL DATA INPUT (RxD) 


CPU BYTE (5-8 BITS/CHAR)* 

if 


DATA CHARACTER 

if 






START 

DATA CHARACTER 

PARITY 


BIT 

BIT 

^Ei^H 


Figure 3-16. Synchronous Mode 
Transmission Format 


Figure 3-18. Asynchronous Mode 
Transmission Format 
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3-50. SYNC CHARACTERS 

Sync characters are written to each US ART in the 
synchronous mode only. The USART can be pro- 
grammed for either one or two sync characters; the 
format of the sync characters is at the option of the 
programmer. 


3-51. COMMAND INSTRUCTION 
FORMAT 

The Command instruction word shown in figure 3-19 
controls the operation of the addressed USART. A 
Command instruction must follow the mode and/or 
sync words. Once the Command instruction is writ- 
ten, data can be transmitted or received by the 
USART. 

It is not necessary for a Command instruction to 
precede each data transaction; only those transmis- 
sions that require a change in the Command instruc- 
tion. An example is a change in the transmit enable 
or receive enable bits. Command instructions can be 
written to the USART at any time after one or more 
data operations. 

After initialization, always read the chip status and 
check for the TXRDY bit prior to writing either data 
or command words to the USART. This ensures that 
any prior input is not overwritten and lost. Note that 
issuing a Command instruction with bit 6 (IR) set will 
return the USART to the Mode instruction format. 



Figure 3-19. USART Command Instruction 
Word Format 


3-52. RESET 

To change the Mode instruction word, the USART 
must receive a Reset command. The next word writ- 
ten to the USART after a Reset command is assumed 
to be a Mode instruction, similarly, for sync mode, 
the next word after a Mode instruction is assumed to 
be one or two sync characters. All control words 
written into the USART after the Mode instruction 
(and/or the sync character) are assumed to be Com- 
mand instruction. 

Note that an individual USART can be reset by bit 6 
(IR) in the Command word; all four USARTs can be 
reset by a board reset or by a system reset operation. 


3-53. ADDRESSING 

Each of the four USART chips uses two consecutive 
addresses. The lower of the two addresses is used to 
read and write I/O data; the upper address is used to 
write mode and command words and to read the 
USART status. (Refer to table 3-2.) 


3-54. INITIALIZATION 

A typical USART initialization and I/O data se- 
quence is presented in figure 3-20. Each USART chip 
is initialized in four steps: 

a. Reset USART to Mode instruction format. 

b. Write Mode instruction word. One function of 
mode word is to specify synchronous or asyn- 
chronous operation. 

c. If synchronous mode is selected, write one or two 
sync characters as required. 

d . W rite Command instruction word . 

To avoid spurious interrupts during USART in- 
itialization, disable the corresponding USART inter- 
rupts. This can be done by either masking the ap- 
propriate interrupt request inputs at the PIC or by 
disabling the 8085A microprocessor interrupts by 
executing a DI instruction. 

a. Individual USART Reset 

(1) Write Command instruction to desired 
USART (Dl). Command instruction word 
must have bit 6 set (IRl); all other bits are 
immaterial. 

NOTE 

The reset procedure should be used only if 
the USART has been completely initialized, 
or the initialization procedure has reached 
the point that the USART is ready to receive 
a Command word. For example, if the reset 
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:RSTU PERFORMS A HARDWARE RESET ON THE FOUR USARTS 

;USES-NOTHING DESTROYS-A 



PUBLIC 

RSTU 


RSTU: IN 

0E9H 

;READ CURRENT DATA ON PORT A 

ORI 

10H 

;SET BIT 4 TO PERFORM RESET 

OUT 

0E9H 


ANI 

OEFH 

; RESET BIT 4 

OUT 

0E9H 


RET 



END 




Table 3-23. Typical USART Mode or Command Instruction Subroutine 


;CMD2 OUTPUTS CONTROL WORD TO USART 2 (PORT 2) 
:USES-A, STAT2; DESTROYS-NOTHING 



PUBLIC 

CMD2 



EXTRN 

STAT2 


CMD2: 

PUSH 

PSW 


LP: 

CALL 

STAT2 



ANI 

1 

iCHECKTXRDY 


JZ 

LP 

;TXRDY MUST BE TRUE 


POP 

PSW 



OUT 

0D5H 

;ENTER HERE FOR INITIALIZATION 


RET 




END 




PORTO 

ADDRESS 

X + 1 

X + 1 

X + 1 

X + 1 


X +0 


X + 1 


X +0 


X + 1 


*THE SECOND SYNC CHARACTER IS SKIPPED IF MODE 
INSTRUCTION HAS PROGRAMMED USART TO SINGLE 
CHARACTER INTERNAL SYNC MODE. BOTH SYNC 
CHARACTERS ARE SKIPPED IF MODE INSTRUCTION 
HAS PROGRAMMED USART TO ASYNC MODE. 

Figure 3-20. Tjrpical USART Initialization 
and Data I/O Sequence 


MODE INSTRUCTION 


SYNC CHARACTER 1 


SYNC CHARACTER 2 


COMMAND INSTRUCTION 


DATA I/O 


COMMAND INSTRUCTION 


DATA I/O 


COMMAND INSTRUCTION 


SYNC MODE 
ONLY 


command is written when the initialization 
sequence calls for a sync character, then 
subsequent programming will be in error. 

(2) Repeat step (2) for remaining USART chips 
to be initialized. Addresses D3, D5, D7. 

b. The following is a typical procedure used to reset 
all the USART chips: 

First, reset the USART chips individually or reset all 
USART chips simultaneously by setting and re- 
setting bit 4 of the 8155. At the top of the page is a 
typical reset routine. Refer to paragraph 3-39 for 
detailed 8155 PPI progr amming . 


Next, write a Mode instruction word to the desired 
USART. (See figures 3-15 through 3-18.) A typical 
subroutine for writing both Mode and Command in- 
structions to USART 2 (Port 2) is given in table 3-23. 
If the USART is programmed for the synchronous 
mode, write one or two sync characters depending on 
the transmission format. 
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Finally, write a Command instruction word to the 
desired USART. Refer to figure 3-19 and table 3-23. 

3-55. OPERATION 

Normal operating procedures use data I/O read and 
write, status read, and Command instruction write 
operations. Programming and addressing procedures 
for the above are summarized in following 
paragraphs. 

Prior to any operating change, a new command word 
must be written with command bits changed as ap- 
propriate. (Refer to figure 3-19 and table 3-23.) 


3-56. DATA INPUT/OUTPUT. For data receive 
or transmit operations perform a read or write, 
respectively, to the desired USART. Tables 3-24 and 
3-25 show examples of typical character read and 
write subroutines for USART 1 . 

During normal transm.it operation, each USART 
generates a Transmit Ready (TXRDY) signal that in- 
dicates that the USART is ready to accept a data 


character for transmission. TXRDY is automatically 
reset when the 8085A loads a character into the 
USART. 

Similarly, during normal receive operation, each 
USART generates a Receive Ready (RXRDY) signal 
that indicates that a character has been received and 
is ready for input to the 8085A. RXRDY is 
automatically reset when a character is read by the 
8085A. 

The TXRDY and RXRDY outputs of each USART 
are connected to the Programmable Interrupt Con- 
troller chip (PIC) which resolves priority in case of 
simultaneous inputs and generates an interrupt for 
the 8085A. TXRDY and RXRDY are also available 
in the status word. (Refer to paragraph 3-57.) 


3-57. STATUS READ. The 8085 A can determine 
the status of a serial I/O port by issuing an I/O Read 
Command to the upper address of the appropriate 
US ART chip. The format of the status word is shown 
in figure 3-21. A typical status read subroutine for 
Port 0 is given in table 3-26. 


Table 3-24. Typical USART Data Character Read Subroutine 


;RX1 READS DATA CHARACTER FROM USART 1 {PORT1) 
:USES-STAT1: DESTROYS-A, FLAGS 



PUBLIC 

RX1,RXA1 



EXTRN 

STAT1 


RX1: 

CALL 

STAT1 



ANI 

2 

;CHECK FOR RXRDY 


JZ 

RX1 


RXA1: 

IN 

0D2H 

.•ENTER HERE IF RXRDY IS TRUE 


RET 




END 




Table 3-25 . Typical USART Data Character Write Subroutine 


:TX1 WRITES DATA CHARACTER FROM REG A TO USART 1 (PORT 1) 
;USES-STAT1: DESTROYS-A, FLAGS 



PUBLIC 

TX1,TXA1 



EXTRN 

STAT1 


TX1: 

PUSH 

PSW 

:SAVE DATA 

TX11: 

CALL 

STAT1 



ANI 

1 

;CHECK FOR TXRDY 


JZ 

TX11 



POP 

PSW 


TXA1: 

OUT 

0D2H 

iENTER HERE IF TXRDY IS TRUE 


RET 




END 
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Figure 3-21 . USART Status Read Format 


Table 3-26. Typical USART Status Read Subroutine 


;STAT0 READS STATUS FROM USART 0 (PORT 0) 

;DESTROYS-A 


PUBLIC 

STATO 

STATO: 


IN 

0D1H 

RET 


END 
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3-58. 8085A INTERRUPT HANDLING 

Included in the 8085A CPU are five interrupt inputs: 
TRAP, RST 7.5, RST 6.5, RST 5.5, and INTR. The 
three “restart” interrupts (RST 7.5, RST 6.5, and 
RST 5.5) are maskable; the TRAP is also a “restart” 
interrupt, but is non-maskable. 

The RST 7.5, RST 6.5, and RST 5.5 interrupts cause 
the internal execution of an RST instruction if the in- 
terrupts are enabled and if the interrupt mask is not 
set by a previously executed SIM instruction. The 
non-maskable TRAP interrupt causes the execution 
of an RST instruction independent of the state of the 
interrupt enable or interrupt mask. The priority and 
vector location of each of the restart interrupts are 
given in table 3-27. 

On the iSBC 544, the interrupt inputs of the on- 
board 8085A CPU have been default connected as 
follows: 

TRAP = not connected (Jumper available for 
PFIN/ - Power Fail Interrupt). 

RST 7.5 = connected to the Timer outputs of the 
8155 (TINTO and Counter Five of the 
8253 (TINTl). 

RST 6.5 = connected to the serial port Ring 
Indicators (RINT) and the serial port 
Carrier Detect signals (PINT). 

RST 5.5 = connected to Flag Interrupt (FINT) and 
optionally to one of the interrupt lines 
from the Multibus (INTO/ - INT 7/). 

INTR = connected to the output of the 8259 PIC 
which monitors the interrupts from the 
8251 US ARTS. 


Table 3-27. Interrupt Vector Memory Locations 


Interrupt 

Vector 

Location 

Priority 

TRAP 



24 

Highest 

Timer 


RST 7.5 

3C 

2nd 

Ring Indicator 
Carrier Detect 


RST 6.5 

34 

3rd 

Flag Interrupt 


RST 5.5 

2C 

4th 

RXRDYO 



40 


TXRDYO 



48 


RXRDY1 



50 


TXRDY1 


INTR 

58 

Lowest 

RXRDY2 


60 


TXRDY2 



68 


RXRDY3 



70 


TXRDY3 



78 



Note: 

1. These are suggested addresses-specified during in- 
itialization of the 8259. 


3-59. TRAP INTERRUPT 

There are special considerations that must be made 
when the TRAP interrupt is used. The fact that the 
TRAP interrupt is non-maskable can present pro- 
blems in at least two areas. 

Interrupt driven systems often contain parameters 
that must be modified only within critical regions. A 
critical region can be roughly defined as a section of 
code that once begun must complete execution before 
it or another critical region that corresponds to the 
same system parameter(s) can be executed. A TRAP 
interrupt handler cannot safely alter such parameters 
either directly or indirectly by causing the execution 
of procedures or tasks that may alter such 
parameters. 

If the hardware generates a TRAP interrupt on 
power up or power fail, the system must be able to 
process the TRAP interrupt before it is completely 
initialized. It should also take into account that an in- 
terrupt routine that runs with interrupts disabled can 
still be interrupted by a TRAP. Power Fail Sense 
status can be read by inputting bit 5 of Port C of the 
8155. 

Because of these considerations, it is recommended 
that the TRAP interrupt only be used for system star- 
tup and/or catastrophic error handling such as a 
power failure. 

It should be noted that TRAP does not destroy a 
previously established interrupt enable status. Ex- 
ecuting the first RIM instruction following a TRAP 
interrupt yields the interrupt enable status as it was 
before the TRAP occurred. Following this first man- 
datory RIM instruction, subsequently executed RIM 
instructions provide current interrupt enable status. 


3-60. RST 7.5, 6.5, AND 5.5 INPUTS 

These interrupts can be individually masked by a 
SIM instruction and can thus be prevented from in- 
terrupting the processor. The priorities shown in 
table 3-27 do not take into account the priority of a 
routine that was started by a higher priority inter- 
rupt. An RST 6.5 interrupt can interrupt an RST 7.5 
routine if the interrupts are re-enabled before the end 
of the RST 7.5 routine. 

The RST 7.5 interrupt is rising edge sensitive and can 
be set by a pulse; the request once set by the pulse will 
be remembered until the request is serviced or reset 
by a SIM instruction. The RST 6.5 and 5.5 interrupts 
are high level sensitive and, in order to be recognized 
must remain high. Table 3-28 is a typical routine 
showing the RST 7.5 input being triggered by the 
8155 Timer (TINTO). 
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Table 3-28. Typical RST 7.5 Interrupt Routine 


FUNCTION: INTR75 



DESCRIPTION: WHEN A RST 7.5 IS GENERATED BY THE 8155 (DETERMINED BY 


THE MAIN PROGRAM), THIS ROUTINE STORES THE STATUS WORD 

AND THEN INCREMENTS A COUNT VARIABLE, IT MAY THEN CALL 

A REAL TIME COUNT AND DISPLAY ROUTINE WHICH INCREMENTS 

VARIABLES FOR MILLISECONDS, SECONDS, ETC., AT THE PROPER TIME. 

FINALLY, THE INTERRUPT ROUTINE WILL RESET RST 7.5, RESTORE 

PROCESSOR STATUS WORD, AND ENABLE INTERRUPTS BEFORE RE- 


TURNING TO THE MAIN 

PROGRAM. 

ORG 

003CH 


COUNT 

EQU 00 

; SET TIMER DELAY 

INTR75: 



CALL 

SAVE 

; SAVE STATE OF MACHINE 

LXI 

H, COUNT 

; LOAD H&L WITH LOCATION OF COUNT 

INR 

M 

; INCREMENT THE COUNT 

CALL 

RTC 

; CALL REAL TIME COUNT AND DISPLAY ROUTINE 

MVI 

A,10H 

(NOT SHOWN) 

SIM 


; RESET RST 7.5 

CALL 

El 

RET 

RSTORE 

; RESTORE STATE OF MACHINE 


Table 3-29. PINT and RINT Flop Reset Routine 


iRSTINT PERFORMS A HARDWARE RESET ON THE RING INDICATOR AND 

;CARRIER DETECT EDGE-SENSE FLIP-FLOPS 
;USES-NOTHING DESTROYS-A 


PUBLIC 

RSTINT 


RSTINT: IN 

0E9H 

; READ CURRENT DATA ON PORTA 

ORI 

20H 

; SET BIT 5 TO PERFORM RESET 

OUT 

0E9H 


ANI 

ODFH 

: RESET BIT 5 

OUT 

0E9H 


RET 



END 




3-61 . INTERRUPTS HANDLED BY 
RST 7.5, RST 6.5, and RST 5.5 

The RST 7.5 input to the 8085 A CPU, handles the 
two timer interrupts from the 8155 (TINTO) and 
from the 8253 (TINTl). 

The RST 6.5 input to the 8085A CPU handles the 
Ring Indicator Interrupt (RINT), which is used to 
detect such things as a telephone ringing on one of 
the serial ports and the Carrier Detect Interrupt 
(PINT), which is used to detect the loss of a carrier 
signal on one of the serial I/O ports. If one of these 
interrupts occur, the 8155 PPI must be interrogated 
to determine which port caused the interrupt. The 
source of the interrupt is determined by reading Port 
B of the 8155. To determine if there is a second Car- 
rier Detect interrupt pending, we would reset the 
RINT and PINT edge detect flip flops via the 8155, 
and then read Port B again. The RINT and PINT in- 


terrupts are reset by setting and resetting bit 5 of Port 
A of the 8155. 

The RST 5.5 input to the 8085 A CPU handles the 
Flag Interrupt (PINT) and the Multibus Interrupt 
lines. To determine which interrupt set RST 5.5, look 
at bit 7 of the accumulator (8085A) after executing a 
RIM instruction. This bit will be set by the SID line 
of the 8085 A if a Multibus interrupt occurred. 

The Flag Interrupt monitors the status of the RAM’s 
base address. If an off-board write occurs into the 
base address, FINT will set. This can be used to in- 
dicate to the iSBC 544, that a command has been 
given it by one of the bus masters. The Flag Interrupt 
flop is reset by an on-board read of the RAM’s base 
address. This Flag Interrupt provides a unique inter- 
rupt for each iSBC 544 on the system. The status of 
Flag Interrupt can be determined by inputting bit 4 of 
Port C of the 8155. 
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3-62. INTR INTERRUPT 

The INTR interrupt from the 8259 PIC has the 
lowest priority and is sampled only during the last 
clock cycle of a given instruction. When INTR is ac- 
tive, the Program Counter (PC) is inhibited and three 
bytes, timed by INTA/ pulses, are transferred from 
the PIC to the 8085A. 

a. Byte 1 = Call instruction (1 1001 101) 

b. Byte 2 = Lower byte or routine address. 

c. Byte 3 = Upper byte of routine address. 

The 16-bit routine address must be on a 32-byte 
boundary or a 64-byte boundary as determined by 
the Initialization Control Words previously written 
to the PIC. (Refer to paragraph 3-31.) 

The INTR is enabled or disabled by the program. It is 
disabled by “RESET”, and immediately after an in- 
terrupt is accepted. 


3-63. 8085A INTERRUPT 
GENERATION 

In addition to receiving interrupts from many 
sources, the 8085A is also capable of generating an 
interrupt and sending it out on the Multibus. The 
8085 A uses its SOD line to generate this interrupt. 

The 8085A sets the SOD output by executing a SIM 
instruction with bit 6 and bit 7 of the accumulator set 
to I’s. 


3-64. MASTER MODE 

The iSBC 544 Intelligent Communications Controller 
can also be used as a bus master. In this role, it could 
be used to control a number of iSBC 534 Com- 
munication Expansion boards or other memory and 
I/O expansion boards. 

When using the iSBC 544 as a bus master, there are 
some limiting factors such as: 

a. The iSBC 544 can not operate on the Multibus 
with other masters, because it does not have the 
necessary bus contention logic. 

b . A non-standard clock period . 

c. An unsynchronized BUSY function that stays set 
as long as the 544 is in master mode, which locks 
out other bus masters. 

The iSBC 544 does have an I/O read and I/O write 
line, and a memory read and memory write line. The 
limitations mentioned, must be considered before at- 
tempting to use the iSBC 544 as a controlling bus 
master. 

The iSBC 544 can be put into the master mode in one 
of two ways: 

a. Turn on the master mode switch (SI position 
number 8) located at B6 or C6 on figure 5-1 . 

b. Program the iSBC 544 to operate in the master 
mode, by performing an I/O write command to 
I/O address E4H. 

Both of these methods will set the master mode flop, 
allowing the iSBC 544 to operate as a bus master. 

The iSBC 544 can be taken out of master mode 
(assuming the master mode switch is not set) by a 
system reset or by doing an I/O write to address E5. 
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CHAPTER 4 
PRINCIPLES OF OPERATION 


4-1. INTRODUCTION 

This chapter provides a functional description and a 
circuit analysis of the iSBC 544 Intelligent Com- 
munications Controller. Figures 4-1 and 4-2, located 
at the end of the chapter, are simplified block 
diagrams that illustrate the functional interface bet- 
ween the on-board 8085A and its associated I/O 
devices and the on-board and system interface to the 
dynamic RAM located on the iSBC 544. 


4-2. FUNCTIONAL DESCRIPTION 

The following paragraphs give a brief description of 
the functional blocks that make up the iSBC 544. An 
operational circuit analysis is given starting with 
paragraph 4-14. 


4-3. CLOCK CIRCUITS 

The clock circuit for the iSBC 544 consists of crystal 
Y1 (22.1184 MHz), A15, A26, and A17. This circuit 
produces five frequencies, four (1 .2288 MHz, 1 .8432 
MHz, 2.4576 MHz, and 22.1184 MHz) which can be 
used for all on-board clock timing except the 8085A 
CPU, and one (5.5296 MHz) which is used as an in- 
put to the 8085A CPU and that can be jumpered to 
the Multibus for use as Bus Clock (BCLK/) and Con- 
stant Clock (CCLK/). 

NOTE 

The 5.5296 MHz used for BCLK/ and 
CCLK/ is a non-standard frequency. 

The clock circuit also generates a power up Reset 
signal to initialize the system to a known internal 
state. The Reset signal can also be generated by a in- 
put signal supplied via auxiliary connector P2. 

4-4. 8085A CENTRAL PROCESSOR UNIT 

The 8085A CPU, which is the heart of the iSBC 544, 
performs on-board processing functions and 
generates the addresses and control signals required 
to access memory and I/O devices. The CPU 
multiplexes the 8-bit data bus and the lower eight bits 
of the address bus. During the first part of the 
machine cycle, the lower eight address bits on the ad- 
dress/data bus are strobed into latch A65 by the Ad- 
dress Latch Enable (ALE) signal; the outputs of A65 
are combined with the upper eight bits of the address 


to form the 16-bit address bus. During the remainder 
of the machine cycle; AD0-AD7 pins of the CPU are 
used for data input/outputs. A detailed description 
of the Intel 8085A can be found in the MCS-85 
User’s Manual (98-366C). 


4-5. INTERVAL TIMER AND BAUD 
RATE GENERATORS 

The Interval Timer and Baud Rate Generators con- 
sist of two Intel 8253 Programmable Interval Timer 
chips {All, A28). Each of the PIT chips has three in- 
dependent counters, each of which are separately 
programmable. 

Four of the six independent counters (BDG0-BDG3) 
are connected by default jumpers to the four USART 
chips. The remaining two counters serve as auxiliary 
timers or rate generators. A jumper matrix (pins 
32-34) can be used to connect the timers in series. The 
default jumper connection is from 32 to 33 which 
connects the output of Counter 4 (BDG4) to the 
clock input of Counter 5 (TINTl), thereby creating a 
long interval timer (approximately 1 hr). Counter 4 
(BDG4) can also be used as a secondary baud rate 
clock for the USARTs. 

In addition to the 8253 Timers, there is also a timer 
on the 8155 PPL It is a 14 bit binary counter/timer 
that can be used as an interval timer by the on-board 
8085A CPU. 


4-6. SERIAL I/O PORTS 

The iSBC 544 has four completely independent I/O 
Ports which are controlled by 8251 A USARTs 
(A18-A21). Each port provides either full or half 
duplex communications with modems, data sets, or 
other serial devices. Each serial port converts parallel 
format data into serial format for transmission, or 
converts serial data into a parallel format for use by 
the system. The 8251 A USART chips can support 
virtually any serial data technique currently in use, 
including IBM Bi-Sync. 


4-7. PARALLEL I/O PORT 

The parallel I/O port, which is controlled by an Intel 
8155 Programmable Peripheral Interface chip (A22), 
is designed to support automatic calling units, such 
as the Bell Model 801, and certain other input or out- 
put signals that are not supported by serial 1/ O Ports 
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0 through 3. The 8155 can also be used as parallel 
I/O for controlling other RS232C devices. The 8155 
PPI has two eight bit ports (PA and PB) and one six 
bit port (PC), which are programmed to operate in 
the basic I/O mode. 

Ports B and C are used as input ports, and port A is 
used as an output port. Port C supports either an 
Automatic Calling Unit (ACU) or secondary receive 
data signals (SRXDO-3). Port B receives carrier 
detect (CD) and ring indicator (RI) signals for ex- 
amination by the CPU. Port A supports either an 
Automatic Calling Unit (ACU) or secondary 
transmit data signals (STXDO-3). Port A bits 4 and 5 
are used to reset the 8251 A USARTs and the carrier 
detect and ring indicator interrupt flops respectively. 


4-8. INTERRUPT CONTROL 

The interrupt control portion of the iSBC 544 con- 
sists of an 8259 Peripheral Interrupt Controller 
(A29), the Flag Interrupt Flop (A30), the Carrier 
Detect and Ring Indicator Interrupt Flops (A23, 
A24, and A44) and the five interrupt inputs on the 
8085 A CPU. The priority of the interrupts on the 
iSBC 544 has been predetermined by the way that 
they are default connected to the 8085A. A detailed 
explanation of how the 8085A handles each one of 
these interrupts may be found in paragraph 3-58. 


4-9. PROM CONFIGURATION 

The ROM/PROM on the iSBC 544 consists of either 
4K or 8K bytes. Two sockets A35 and A51 are 
provided for user installation of the PROM chips. 
Jumpers are provided to accommodate the various 
ROM/PROM chips. Address block 0000-1 FFF is 
reserved for ROM/PROM use only. 


4-10. RAM CONFIGURATION 

The iSBC 544 includes 16K of dynamic RAM im- 
plemented with eight Intel 2117 chips and an Intel 
8202 Dynamic RAM Controller (A62). Dual-port 
control logic allows this RAM to be accessed by 
either the on-board 8085A, or by another master 
CPU. The dual-port logic provides a reservation 
scheme for the iSBC 544’s RAM. In its normal 
default state, the dual-port logic has selected the on- 
board processor to have memory. If the off-board 
master CPU wants to access memory, it must cause 
the dual-port logic to set up in a way that will reserve 
memory for it. 

The RAM decode logic allows for extended Multibus 
addressing of up to 20 address lines. This allows bus 
masters with 20-bit addressing capability to partition 
the iSBC 544 into any 4K, 8K, or 16K segment in a 1- 


megabyte address space. The on-board 8085A CPU, 
however, has only a 16-bit address capability, which 
limits it to a 64K address space. 

The iSBC 544 employs a network made up of a 
switch (SI) and a PROM decoder (A41) to determine 
if the Multibus address is a valid address for this 
board, and to transform it into an address within the 
range of the on-board RAM (8000H - BFFFH), for 
use by the Flag Interrupt logic. The iSBC 544 also has 
256 bytes of static RAM located on the Intel 8155 
PPI (A22). This memory is only accessible to the on- 
board 8085 A. The address block for the static RAM 
is 7F00-7FFF. 


4-11. BUS INTERFACE 

The iSBC 544’s Multibus interface consists of bi- 
directional address bus drivers (A73, A74, A75), bi- 
directional data bus drivers (A76, A77), memory 
read/ write lines, and I/O read/write lines. The iSBC 
544 has no Multibus control logic, because when it 
operates as a master, it can be the only master on the 
Multibus. 


4-12. DUAL PORT CONTROL 

The dual port control logic allows the iSBC 544 to 
function as a slave RAM device when operating in 
the “intelligent slave mode.” The dual port logic 
allows access to the on-board RAM by the on-board 
8085A or by some Multibus master. The dual port 
logic reserves the memory for the on-board 8085A if 
a request is imminent. 


4-13. MASTER MODE 

The iSBC 544 has two modes of operation; intelligent 
slave, and master mode. Its normal mode is the in- 
telligent slave mode. The master mode flop (A44) can 
be set by a switch (SI) or by an I/O write command 
to address E4. Once master mode has been set, the 
iSBC 544 will perform as a bus master. It should be 
noted, however, that the iSBC cannot function as a 
dual master because it does not contain the Multibus 
control logic. The iSBC 544 could be used to control 
a number of slave iSBC 534 Communication Expan- 
sion boards. 

The iSBC 544 prevents any use of the Multibus by 
other masters, by keeping the bus busy as long as it is 
in Master Mode. 


4-14. CIRCUIT ANALYSIS 

Figure 5-2 is a schematic diagram of the iSBC 544. 
The schematic diagram consists of 9 sheets, each of 


4-2 



iSBC 544 


Principles of Operation 


which includes grid coordinates. Signals that traverse 
from one sheet to another are assigned grid coor- 
dinates at both the signal source and signal destina- 
tion. For example, the grid coordinates 5ZD1 locate 
a signal source (or signal destination) on sheet 5 zone 
Dl. 

Both active-high and active-low signals are used. A 
signal mnemonic that ends with a virgule (e.g. 
DAT7/) denotes that the signal is active low (<0.8V). 
Conversely, a signal mnemonic without a virgule 
(e.g. ALE) denotes that the signal is active high 
(>2.0V). 


4-15. INITIALIZATION. 

When power is applied in a start-up sequence, the 
contents of the 8085A CPU program counter, in- 
struction register, and interrupt enable flip-flop are 
subject to random factors and cannot be predicted. 
For this reason, a power up sequence is used to set 
the CPU, interrupt flops, and I/O ports to a known 
internal state. 

When power is initially applied to the iSBC 544, 
capacitor C3 (7ZC7) begins to charge through 
resistor R1 . The charge developed across C3 is sensed 
by a Schmitt trigger, which is internal to Clock 
Generator A15. The Schmitt trigger converts the 
slow transition at pin 2 into a clean, fast rising syn- 
chronized PURST output of 3 seconds at pin 1 . The 
PURST signal is inverted by All and A54 (2ZD7) to 
produce the Initialize signal IN IT/. The IN IT/ signal 
clears the 8085A CPU program counter, instruction 
register, and interrupt enable flip-flop; resets the 
parallel I/O port to the input mode; resets the serial 
I/O ports to the idle mode via the 8155; resets the 
Dual Port logic (3ZB8); resets the Flag Interrupt flop 
(5ZA1); resets the Master Mode flop (6ZA8); and 
resets the PINT and RINT Interrupt flops (6ZC5). 
The IN IT/ signal can also be used as a system reset 
by way of jumper 71-70 to the Multibus. 

The initialization sequence described above can be 
triggered by an AUX RESET signal from connector 
P2 (7ZC7), or from INIT/ on the Multibus. 


4-16. CLOCK CIRCUITS (Sheet 7) 

All the on-board clock signals are generated by the 
8224 Clock Generator (A15). The 8224 produces two 
frequencies 22.1184 MHz, and 2.4576 MHz. The 
2.4576 MHz signal is divided by A26 to produce the 
iSBC 534 compatible frequency of 1.2288 MHz 
which is the default frequency used for the 8253 
PIT’s, and for the 8155 Timer. The 2.4576 MHz 
signal (<}>2TTL) is also used for the internal device 
timing of the 8251 USARTs. 


The 22.1184 MHz frequency is divided by four and 
divided by twelve (A26 ad A 17) to produce frequen- 
cies of 5.5296 MHz and 1.8432 MHz. The 5.5296 
MHz frequency is used as the input frequency for the 
8085A CPU and can also be used for BCLK/ and 
CCLK/ by jumpering the 5.5296 MHz signal to the 
Multibus. It should be noted that BCLK/ and 
CCLK/ in this case would not be standard clock fre- 
quencies. The 1.8432 MHz frequency is used as an 
optional jumper selectable input for the 8253 PITs 
and for the 8155 Timer. 


4-17. 8085A CPU TIMING 

The 8085 A CPU internally divides the 5.5296 MHz 
clock input by two to develop the timing re- 
quirements for the various time dependent functions. 
These functions are described in the following 
paragraphs. 


4-18. INSTRUCTION TIMING. The execution of 
any program consists of read and write operations, 
where each operation transfers one byte of data bet- 
ween the CPU and memory or between the CPU and 
an I/O device. Although the CPU can vary the ad- 
dress, data, type, and sequence of operations, it is 
capable of performing only a basic read or write 
operation. With the exception of a few control lines, 
such as Address Latch Enable (ALE), these read and 
write operations are the only communication 
necessary between the CPU and the other com- 
ponents to execute any instruction. 

An instruction cycle is the time required to fetch and 
execute an instruction. During the fetch phase, the 
selected instruction (consisting of up to three bytes) is 
read from memory and stored in the operating 
registers of the CPU. During the execution phase, the 
instruction is decoded by the CPU and translated in- 
to specific processing activities. 

Each instruction cycle consists of up to five machine 
cycles. A machine cycle is required each time the 
CPU accesses memory or an I/O device. The fetch 
phase requires one machine cycle for each byte to be 
fetched. Some instructions do not require any 
machine cycles other than those necessary to fetch 
the instructions from memory; other instructions, 
however, require an additional machine cycle(s) to 
write or read data to or from memory or I/O devices. 

Every instruction cycle has at least one reference to 
memory during which time the instruction is fetched. 
An instruction cycle must always have a fetch, even if 
the execution of that instruction requires no 
reference to memory. The first machine cycle in every 
instruction cycle is therefore a fetch, and beyond that 
there are no specific rules. For instance, the IN (in- 
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put) and OUT (output) instructions each require 
three machine cycles: fetch (to obtain the instruc- 
tion), memory read (to obtain the I/O address of the 
device), and an input or output machine cycle (to 
complete the transfer). 

Each machine cycle consists of a minimum of three 
and a maximum of six states designated T j through 
Tg.A state is the smallest unit of processing activity 
and is defined as the interval between two successive 
falling edges of the CPU clock. Each state (or CPU 
clock cycle) has a duration of 362 nanoseconds 
(derived by dividing the 5.5296 MHz frequency by 
two). 

Every machine cycle normally consists of three T- 
states with the exception of an opcode fetch, which 
consists of either four or six T-states. The actual 
number of states required to execute any instruction 
depends on the instruction being executed, the par- 
ticular machine cycle within the instruction cycle, 
and the number of wait states inserted into the 
machine cycle. The wait state is initiated when the 
READY input to the CPU is pulsed low. 

There are no wait states imposed when the CPU is 
addressing on-board PROM or on-board I/O, or 
static RAM. There will be wait states imposed, 
however, in the following operations: 

a. When addressing on-board RAM and a refresh 
cycle is in progress. 

b. When addressing on-board RAM and a bus 
master is currently reading or writing on-board 
RAM. 

c. When operating in the master mode and 
addressing off-board I/O or memory. 

d When writing to the dynamic RAM . 

Figure 4-3 is presented to show the relationship bet- 
ween an instruction cycle, machine cycle, and T- 
state. This example shows the execution of a Store 
Accumulator Direct (STA) instruction involving on- 
board memory. Notice that for this instruction the 
opcode fetch (machine cycle Mj) requires four T- 
states and the remaining three cycles each require 
three T-states. 

The opcode fetch is the only machine cycle that re- 
quires more than three T-states. This is because the 
CPU must interpret the requirements of the opcode 
fetched during Tj through T3 before it can decide 
what must be done in the remaining T-state(s). 

There are seven types of machine cycles, each of 
which can be differentiated by the states of three 
CPU status lines (l O/M , SO, and SI ) and three CPU 
control lines (RD, WR, and INTA). Table 4-1 lists 
the states of the CPU status and control lines during 
each of the seven machine cycles. 


Table 4-1 . CPU Status and Control Lines 


Machine Cycle 

Status 

Control 

lO/M 

SO 

S1 

RD 

WR 

INTA 

Opcode Fetch 

0 

1 

1 

0 

1 

1 

Memory Read 

0 

0 

1 

0 

1 

1 

Memory Write 

0 

1 

0 

1 

0 

1 

I/O Read 

1 

0 

1 

0 

1 

1 

I/O Write 

1 

1 

0 

1 

0 

1 

INTR Acknowledge 

1 

1 

1 

1 

1 

0 

Bus Idle 

X 

X 

X 

1 

1 

1 

Halt 

TS 

0 

0 

TS 

TS 

1 


4-19. OPCODE FETCH TIMING. Figure 4-4 
shows the timing relationship of a typical opcode 
fetch machine cycle. At the beginning of Tj of every 
machine cycle, the CPU performs the following: 

a. Pulls lO/M low to signify that the machine cycle 
is a memory reference operation. 

b. Drives status lines SO and SI high to identify the 
machine cycle as an opcode fetch. 

c. Places high-order bits (PCH) of program counter 
onto address lines A8-A15. These address bits 
will remain true until at least T4. 

d. Places low-order bits (PCL) of program counter 
onto address/data lines AD0-AD7. These ad- 
dress bits will remain true for only one clock cy- 
cle, after which AD0-AD7 go to their high- im- 
pedance state as indicated by the dashed line in 
figure 4-3. 

e. Activates the Address Latch Enable (ALE) 
signal. 

At the beginning of T2, the CPU pulls the RD/ line 
low to enable the addressed memory device. The 
device will then drive the AD0-AD7 lines. After a 
period of time, as determined by the access time of 
the addressed memory device, valid data (the DCX 
instruction in this example) will be present on the 
D0-D7 lines. During T3 the CPU loads the data on 
the D0-D7 lines into its instruction register and drives 
RD/ high, disabling the addressed memory device. 
During T4 the CPU decodes the opcode and decides 
whether or not to enter T5 on the next clock cycle or 
start a new machine cycle and enter T | . In the case of 
the DCX instruction, the CPU will enter T5 and then 
T5 before beginning a new machine cycle. 

Figure 4-5 is identical to figure 4-4 with one excep- 
tion, which is the use of the READY input to the 
CPU. As shown in figure 4-5; the CPU examines the 
state of the READY input during T2. If the READY 
input is high, the CPU will proceed to T3 as shown in 
figure 4-4. If the READY input is low, however, the 
CPU will enter the T^^jj state and stay there until 
READY goes high. When READY goes high, the 
CPU will exit the T^^it enter T 3 . The exter- 

nal effect of using the READY input is to preserve 
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Figure 4-3. Typical CPU Instruction Cycle 
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Figure 4-4. Opcode Fetch Machine Cycle (No Wait) 


the exact state of the CPU signals at the end of T 3 for 
an integral number of clock periods before finishing 
the machine cycle. This stretching of the system tim- 
ing, in effect, increases the allowable access time for 
memory or I/O devices. By inserting T^y^it states, the 
CPU can accommodate slower memory or slower 
I/O devices. It should be noted, however, that access 
to the on-board PROM and I/O ports does not im- 
pose a T^ait state. However as mentioned previous- 
ly > states are imposed in certain instances when 

accessing on-board RAM. T^^it states are also im- 
posed when the iSBC 544 is in the master mode and is 
accessing off-board memory or I/O. 


4-20. MEMORY READ TIMING. Figure 4-6 
shows the timing of two successive memory read 


machine cycles, the first without a T^^it 
the second with a one T^^it state. Disregarding the 
states of the SO and SI lines, the timing during Tj 
through T 3 is identical with the opcode fetch 
machine cycle shown in figure 4-2. The major dif- 
ference between the opcode fetch and memory read 
cycles- is that an opcode fetch machine cycle requires 
four or six T-states whereas the memory-read 
machine cycle requires only three T-states. One 
minor difference between the cycles is that the 
memory address used for the opcode fetch cycle is 
always the contents of the program counter (PC), 
which points to the current instruction; the address 
used for a memory read cycle can be one of several 
origins. Also, the data read from memory is placed 
into the appropriate register instead of the instruc- 
tion register. Note that a T^^j^ state is not imposed 
during a read of on-board PROM. 
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Figure 4-6. Memory Read (or I/O Read) Machine Cycle 


4-21. I/O READ TIMING. Figure 4-6 also il- 
lustrates the timing of two successive I/O read 
machine cycles, the first without a state and 

the second jwith one T^^it state. With the exception 
of the lO/M status signal, the timing of a memory 
read cycle and ^ I/O read cycle is identical. For an 
I/O read, lO/M is driven high to identify that the 


current machine cycle is referencing an I/O port. One 
other minor exception is that the address used for an 
I/O read cycle is derived from the second byte of an 
IN instruction; this address is duplicated onto both 
the A8-A15 and AD0-AD7 lines. The data read from 
the I/O port, specified by the IN instruction, is 
always placed in the accumulator. Note that a T^^it 
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Figure 4-7. Memory Write (or I/O Write) Machine Cycles 


is not imposed during the access of on-board I/O 
devices; states are imposed during the access of 
system I/O device via the Multibus. 


4-22. MEMORY WRITE TIMING. Figure 4-7 
shows the timing of two successive memory write 
machine cycles, the first without a T^^j^ state. 
Again, disregarding the states of the SO and SI lines, 
the timing during T j is identical to the timing of an 
opcode fetch, memory read, and I/O read cycles. 
The difference occurs, however, at the end of T j . For 
instance, in a memory read cycle the AD0-AD7 lines 
are disabled (high impedance) at the beginning of T 2 
in anticipation of the returned data. In a memory 
write cycle, the AD0-AD7 lines are not disabled and 
the data to be written into memory is placed on these 
lines at the beginning of T 2 . The Write (WR/) line is 
driven low at this time to enable the addressed 
memory device. During T 2 the READY input is 
checked to determine if a state is required. If 

the READY input is low, T^^it states are inserted 
until READY goes high. During T 3 , the WR/ line is 
driven high to disable the addressed memory device 
and terminate the memory write operation. Note that 
the contents on the address and data lines do not 
change until the next T 1 state. 


4-23. I/O WRITE TIMING. Figure 4-7 also il- 
lustrates the timing of the two successive I/O write 
machine cycles, the first without a T^^^it 
the second with one With the exception of the 

lO/M status signal, the timing of a memory write cy- 
cle and an I/O write cycle are identical. 


4-24. INTERRUPT ACKNOWLEDGE TIMING. 

Figure 4-8 shows the CPU timing in response to the 
INTR input being driven high by the 8259 PIC. It is 
assumed that the CPU interrupt enable flip- flop has 
been set by a previously executed Enable Interrupt in- 
struction. The status of the TRAP, RST 7.5, RST 
6.5, RST 5.5, and INTR inputs are sampled during 
CLK of the T-state immediately preceding Tj of the 
Ml machine cycle. If INTR was the only valid inter- 
rupt, the CPU would clear its interrupt enable flip- 
flop and enter the Interrupt Acknowledge (IN A) 
machine cycle. With two exceptions, the INA 
machine cycle is identical to the Opcode Fetc^(OF) 
machine cycle. The first exception is that lO/M = 1, 
which signifies that the opcode fetched will be fro m 
an I/O device. The second exception is that INTA is 
asserted instead of RD. Although the contents of the 
CPU program counter is sent out on the address 
lines, the address lines are ignored. 

When INTA is asserted, the PIC provides a CALL 
instruction which causes the CPU to push the con- 
tents of the program counter onto the stack before 
jumping to a new location. After receiving the CALL 
opcode, the CPU performs a second INTA machine 
cycle (M 2 ) to access the second byte of the CALL in- 
struction from the PIC. The timing of M 2 is identical 
with Mj except that M 2 has three T-states. M 2 is 
followed by M 3 to access the third byte of the CALL 
instruction. When all three bytes have been received, 
the CPU executes the instruction. The CPU inhibits 
the incrementing of the program counter during the 
three INTA cycles so that the correct program 
counter value can be pushed onto the stack during 
M 4 and M 5 . 
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Figure 4-8. Interrupt Acknowledge Machine Cycles 
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During M 4 and M 5 , the CPU performs Memory 
Write (MW) machine cycles to write (push) the con- 
tents of the program counter onto the top of the 
stack. The CPU then places the two bytes accessed 
during M 2 and M 3 into the upper and lower bytes of 
the program counter. This has the same effect as 
jumping the execution of the program to the location 
specified by the CALL instruction. 

After the interrupt service routine is executed, the 
CPU sets the interrupt enable flip-flop, pops the 
stack and loads it into the program counter, and 
resumes system operation at the point of interrupt. 


4-25. ADDRESS BUS (SHEET 2) 

Figure 4-9 is a block diagram of the iSBC 544 Ad- 
dress Bus. The iSBC address bus is also shown in 
figures 4-1 and 4-2 as a weighted line. The upper 
eight bits of the address bus are fed by A8-A15 of the 
8085A. The lower eight bits of the address bus are fed 
by AD0-AD7 (8085 A Data Bus) through latch A65. 
AD0-AD7 are used during T j of a machine cycle to 
output the lower eight bits of an address. During T 2 
and T 3 of the machine cycle AD0-AD7 input or out- 
put data. The 16 address lines PAB 8 -PABF from the 
8085A and PAB0-PAB7 from latch A65 are 
distributed as follows: 

a. PABO-PABB to the PROM chips A35 and A51 
(4ZD3). 

b. PAB 8 -PABF to lO/M Address Decode PROM 
(A50) for chip select and buffer control logic 
(4ZB3). 

c. PABO-PABF to RAM Address Buffers (A63 and 
A64), RADO-RADF from the RAM Address 
Buffers to the RAM Controller A62 (5ZD6). 

4-26. DATA BUS (SHEET 2) 

Figure 4-10 is a block diagram of the data bus. The 
data bus (AD0-AD7) is used for outputting and in- 
putting data to/from the 8085 A CPU. The data bus 
is distributed as follows: 

a. PDB0-PDB7 to/from RAM Transmitter/ 
Receiver A 66 (5ZD2). 

b. PDB0-PDB7 to/from 8155 PPI A22 ( 6 ZA 8 ). 

c. PDB0-PDB7 to/from I/O Transmitter/Receiver 
A67 (2ZC2). 

d. IODBO-IODB7 to/from PROM chips A35 and 
A51 (4ZD1). 

e. IODBO-IODB7 to/from 8259 PIC A29 (7ZB8). 

f. IODBO-IODB7 to/from 8251 A USARTS A18 
and A19 ( 8 ZB 8 ) and A20, A21 (9ZB8). 

g. IODBO-IODB7 to/from 8253 PITs All and A28 
(7ZC2). 



MBEN = (ONBD I/O + PROM) (SEL ONBD) 

SBEN = SELECT ONBD + BUS MASTER GATE (BMG) 

Figure 4-9. Address Bus and Buffers 


lOB 



BMG = 0 - IN 
1 — OUT 


lOBEN = lOBCS ■ CMD + INTA 

MBEN = ONBD I/O + PROM - SEL ONBD 

SBEN = SELECT ONBD + BUS MASTER GATE (BMG) 


Figure 4-10. Data Bus and Buffers 


4-27. READ/WRITE COMMAND 
GENERATION 

Figure 4-11 is a block diagram of the Command and 
Acknowledge logic. The Read/Write Command logic 
is divided into memory commands and I/O com- 
mands. All of th ese c ommands are derived from the 
8085 A’ s RD and WR outputs, its lO/M output, and 
from the status lines SO and SI shown in table 4-1. 
These signals are used, so that the on-board 8085A 
can avoid wait states, which would occur if the com- 
mands were not decoded. 

4-28. I/O COMMANDS (SHEET 2). The iSBC 
544’s I/O signals, lOR/, lOW/ an^IOCMD (2ZB2) 
are derived by gating the CPU lO/M, RD/ and WR/ 
outputs. The I/O Command (lOCMD) is used by the 
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MB = SEL ONBD 
BM = BMG • ONBD CMD 
SB = SBS (SEL OFF BD) 


Figure 4-1 1 . Command and Acknowledge Logic 


lO/M Decode PROM for Chip select and for I/O 
bus control (4ZC8), and by the 8155 PPI to select the 
I/O portion of the chip (6ZB8). 

The I/O Read Command (lOR/) is used to generate 
an off-board I/O Read in the master mode, and by 
the 8259 PIC, 8251 A USARTs and 8253 PITs to per- 
form an I/O read. 

The I/O Write Command (lOW/) is used by the 
8259, and 8253 PITs, and the 8251 A USARTs to per- 
form an I/O write, and is used to control the Master 
Mode flop if it is an I/O write to address E4 or E5 
(6ZA6). 


4-29. MEMORY COMMANDS (SHEET 2). The 

memory command signals on the iSBC 544 consist 
of, RD/ and WR/ directly from the 8085A, Memory 
Write (MW/), Advanced Memory Read (AMR), and 
Advance Command (ACMD/). 


The RD/ and WR/ signals are used by the 8155 PPI. 
The RD/ signal is also used as a chip select on PROM 
chips A3 5 and A51. The MW/ signal is used to write 
data into the dynamic RAM. 

The Advance Commands are generated because of 
timing restraints. In order for the 8085A to continue 
in its cycles when it sees a read or write command, the 
addressed device must return a READY to the CPU. 
If this doesn’t occur, the 8085A will go into a wait 
state. The normal commands RD/ and WR/ are 
generated just after the READY sample point and 
therefore would cause wait states to occur if they 
were used. To avoid this problem, the iSBC 544 uses 
the status indicators (SO and SI) to generate what are 
called Advance Commands (AMR/, AMR, and 
ACMD/). Figure 4-12 shows the relationship of nor- 
mal commands and advance commands. An advance 
memory write is not used, because the data is not 
available soon enough to be used by the RAM.- 
Therefore one wait state will be incurred, on memory 
writes. 

Decoder A46 and latch A45 (2ZB4) are used to 
generate the Advance commands. The two chips 
decode the status of SI and SO from the CPU to 
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create AMR, AMR/, and ACMD/. The ACMD/ 
function is used by the Dual Port logic to reserve the 
memory for the on-board 8085A processor. 

There is one other set of commands generated by the 
iSBC 544, called Qualified Commands. These com- 
mands are only used when the iSBC 544 is operating 
in the master mode. The two commands (QMW/ and 
QIOW/) are necessary because when the 544 goes out 
to the Multibus, data must be stable for 50 nano- 
seconds before it gets a command. To accomplish 
this, the 544 qualifies the commands with a clock 
pulse through A43 (2ZA4) and produces the qualified 
Commands. 

4-30. DUAL PORT CONTROL LOGIC 

The Dual Port Control logic (figure 5-2, sheet 3) 
allows the on-board RAM to be shared by the on- 
board 8085A CPU and by another bus master via the 
Multibus. The iSBC 544 acts as a “slave” RAM 
device to other bus masters. When accessing its on- 
board RAM, the on-board CPU has priority over any 
attempt to access the on-board RAM via the 
Multibus. In this situation, the bus access is held off 
until the CPU has completed its particular read or 
write operation. When a bus access is in progress, the 
Dual Port logic holds off any subsequent CPU re- 
quest until the bus access is terminated. 

4-31. BUS MASTER RAM ACCESS. The Dual 
Port Logic is controlled by the three flip-flops shown 
at the bottom of sheet 3. The normal state of the flip- 
flops after reset, selects the on-board CPU to have 
access to memory. If the bus master wants access to 
memory, it must cause all three flip-flops to toggle. 
The first flip flop (A37-5) will set if the following 
conditions are true, and a clock pulse occurs: 

a. Previous RAM access is over (ACK/ asserted). 

b. The on-board processor does not want memory 
(ALE/ and CSMO/ high). 

c. There is a request from the bus (MWTC/ or 
MRDC/) and the address is within the iSBC 
544’ SRAM. 

The second flip-flop (A36-9) will set if the following 
conditions are met: 

a. Flop A37-5 is set. 

b. The on-board processor still does not want access 
(CSMO/ or ACMD/ high). 

c. The address is within the iSBC 544’s RAM. This 
gate is necessary, because of the amount of time 
it takes for the address to get through the address 
decode logic. 

When flop A36-9 sets, it latches itself through A70. 
The output of the flop activates System Bus Enable 
(SBEN/) which gates the off-board address into the 


inputs of the 8202 RAM Controller (5ZD6) and 
System Bus Direction Control (SBDC/) which allows 
the data from the Multibus into the RAM (5ZC3). It 
also disables MBEN/ which prevents an on-board 
address and on-board data from getting to the RAM. 

When the last flip-flop in the string sets (A36-6), the 
negation output goes low activating the Command 
Buffer A60 (3ZD3) and allowing the bus master’s 
command (MWTC/ or MRDC/) to be gated to the 
RAM controller (5ZC6). The negation output also 
activates Dynamic RAM Chip Select (DRCS/) which 
selects the RAM controller. 

After the RAM accepts the command, it will send out 
an acknowledge (SACK/) which will allow the flip- 
flops to start to reset. The MEM ACK/ signal from 
the RAM controller is gated out to the Multibus 
(through A71) to generate XACK/ (Transfer 
Acknowledge) which notifies the bus master that its 
command has been acknowledged. 

The acknowledge signal (SACK/) starts the clearing 
process for the dual-port flip-flops. When SACK/ 
occurs, the output of A53 (3ZB6) will go low disabl- 
ing the input to A37 (pin 2). The next clock pulse will 
clear A37 (pin 5). When XACK/ occurs, the bus 
master will drop its command. The output of A38-6 
will go low and the output of A54-2 will go high. The 
termination of the command also causes SACK/ to 
go high (via the 8202, A62). With both inputs to A57 
true, its output will go high. Consequently, on the 
next clock pulse, A37-9 will set. This removes the 
preset from A36 (pin 10). A36 (pin 9) will reset on the 
next clock pulse, which will allow A36 (pin 6) to clear 
on the following pulse. The flops are now back in the 
normal state, which is set up to favor the on-board 
CPU’s RAM requests. 


4-32. ON-BOARD CPU RAM ACCESS. As 

previously mentioned, the Dual Port Control logic 
flip-flops are normally in a state which favors an on- 
board access. When the on-board processor wants to 
access RAM, it generates a read command (AMR/) 
or a write command (MW/) which is gated to the 
8202 RAM controller through the Command Buffer 
A60 (3ZD3). The gating is controlled by A38 which 
looks at CSMO/ (On-Board Memory Chip Select) 
and the negation side of flip-flop A36-6 which is nor- 
mally high. The output of A36 (3ZA3) also generates 
DRCS/ which selects the on-board RAM through the 
8202 RAM Controller. MBEN/ (Memory Bus 
Enable) which is normally low allows the 8085 A CPU 
address (4ZC7) and data (5ZD2) to be gated to the 
RAM. 

After the RAM receives the command, it generates 
an acknowledge (SACK/) which is gated to the CPU 
Ready logic by A40 (3ZC2). This tells the CPU that 
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the RAM has received the command and a refresh is 
not in progress, which allows the CPU to continue its 
cycling. 

4-33. OFF BOARD MEMORY REQUEST 

When operating in Master Mode, the iSBC 544 is 
capable of generating commands to off-board 
memory and off-board I/O (such as an iSBC 534 I/O 
Expansion board). 

The off-board commands for memory AMR/ (Ad- 
vance Memory Read) and QMW/ (Qualified 
Memory Write), are gated on to the Multibus by OFF 
BD REQ/. OFF BD REQ/ (3ZB1) says that the iSBC 
544 is in Master Mode (MASMD/) and the 8085A ad- 
dress is not for the on-board RAM (ONBD/). These 
commands go out on the bus where they are process- 
ed by the addressed external board. 

When the off-board memory processes the com- 
mand, it sends back an acknowledge XACK/ (3ZA1) 
which is used by the 8085 A CPU’s READY logic. 
XACK/ is anded with OFF BD REQ/ to generate 
READY on the input to the 8085A. Allowing the 
8085A to terminate the command and go on with the 
next command. 


4-34. I/O OPERATION 

The following paragraphs describe on-board and 
system I/O operations. The actual functions per- 
formed by specific read and write commands to on- 
board I/O devices are described in Chapter 3. 

4-35. ON-BOARD I/O OPERATION. During an 
on-board I/O operation, the address of the selected 
device is sent out on the upper 8 bits of the 8085A 
CPU address bus. The upper 8 bits (PAB8-PABF) 
are applied to PROM Decoder A50 (4ZB3). The ad- 
dress selected in the PROM will contain the necessary 
bit configuration to activate the chip and the cor- 
responding I/O control lines. For example, if the I/O 
command is to the 8259 PIC the CPU would address 
E6. Addressing E6 in the PROM will produce a bit 
configuration of ID (00011101). The lower four bits 
are applied to the 8205 Decoder A32 (4ZB2) where 
they select outppt 5. Output 5 (CSIO/) is the chip 
select for the 8259 PIC chip A29 (7ZB7). The upper 3 
bits (000) activate the I/O functions lOBA/ (I/O Bus 
Allow), lOACK/ (I/O Acknowledge), and ONBD/ 
(On-Board Address) which are used in the execution 
of the I/O command. A complete list of all Decode 
PROM (A50) locations is found in Appendix C. 

After the I/O device has been selected, specific func- 
tions for the chips are selected by PABO and PABl 
(Processor Address Bits 0 and 1). For example ad- 


dresses D8, D9, DA, and DB all select the 8253 PIT 
chip, but different counters on the chip. (Refer to 
table 3-2 for a further breakdown.) 

Along with selecting the I/O chip, the 8085A also 
generates the following signals, lOCMD/ (I/O Com- 
mand), lOR/ (I/O Read), and lOW/ (I/O Write). 
lOCMD/ is used by the Decode PROM (A50) to ac- 
tivate the I/O control signals, and by the 8155 PPI to 
select the I/O portion of the chip (6ZC2). lOR/ is us- 
ed by the 8253 PIT, the 8259 PIC, and by the 8251A 
USART’s to perform a read operation. The lOR/ 
signal is also used to feed the Multibus when the 
iSBC 544 is in the Master Mode and wants to per- 
form and external I/O read (3ZD7). lOW/ is used on 
the same chips as lOR/ to allow them to perform a 
write operation, and is used by the iSBC 544 to con- 
trol the Master Mode flop. 

After the I/O address has been decoded, and it is 
determined that the CPU is executing an I/O com- 
mand, lOACK/ (I/O Acknowledge is generated by 
A50 (4ZB1) and drives the 8085A CPU’s READY 
line. This allows the CPU to proceed to the next 
machine cycle and finish executing the I/O com- 
mand. 


4-36. SYSTEM I/O OPERATION. Address bits 
PAB8-PABF are decoded by Decode PROM A50 
described in paragraph 4-35. If the address is not for 
an on-board I/O device, ONBD/ remains false. If 
the iSBC 544 is in the Master Mode, MAMSD true 
and ONBD/ false AND together at A39 (3ZB2) to 
produce OFF BD REQ/ (Off Board Request). OFF 
BD REQ/ gates the I/O command (lOR or QIOW) 
on to the Multibus (3ZD7) to be transferred to an ex- 
ternal device. The off-board device acknowledges the 
command and sends back XACK/ true via the 
Multibus (3ZA2), to drive the 8085A CPU’s READY 
line. 

The data transfer is controlled by SBDC/ (System 
Bus Data Control). On an off-board I/O read opera- 
tion, SBDC/ would be true allowing the data 
(DAT0/-DAT7/) from the Multibus to be gated 
through the Bi-directional Bus Drivers (5ZC2) on to 
the processor data bus (PDB0-PDB7). On an off- 
board 1/ O write, SBDC/ would be false, allowing the 
processor data bus (PDB0-PDB7) to be gated out to 
the Multibus (DAT0/-DAT7). 


4-37. ROM/PROM OPERATION 

The two ROM/PROM chips are installed by the user 
in IC sockets A35/A51 (4ZD3). Memory addresses 
0000 - IFFF are reserved exclusively for ROM/ 
PROM; the actual occupied memory space depends 
on the ROM/PROM chips used: 
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Chip 

Chip Addresses In 

Size 

A35 

A51 

2Kx8 

0000-07FF 

0800 -OFFF 

4Kx8 

0000 -OFFF 

1000-1FFF 


When the 8085A CPU is addressing ROM, bits 
PABO- PABB are applied directly to the PROM 
chips, and bits PAB8-PABF are applied to the 
PROM Decoder chip A50 (4ZB3). If the address is 
within the range of the iSBC 544’s ROM, the output 
bit configuration from A50 will select output 00 
(CSPRO/) or 01 (CSPRl/) of 8205 A33 (4ZC2), and 
cause lOACK/ (I/O Acknowledge) to be true. 
CSPRO/ and CSPRl are used to power up the 2716 
chips. These signals and RD/ from the 8085A CPU 
activate the PROM chip which contains the location 
that is being addressed by PABO-PABB. lOACK/ 
drives the CPU READY line, signifying the 
acknowledgement of the command by the ROM. 

When 2732A/2332 ROM/PROM chips are used. 
Advanced Memory Read (AMR) is gated into the 
chip select logic (CSPRO/ and C!SPR1/) to provide 
the required timing on each memory cycle. This is 
accomplished by jumpering 45 to 46. 

The data outputs from the ROM (IODBO/-IODB7/) 
are gated through the Bi-Directional Data Buffer 
A67 (2ZC2) by CPU status signal SI (S 1=1 for Read) 
to the CPU. 


4-38. RAM OPERATION 

As described in paragraph 4-30, the Dual Port Con- 
trol logic allows the on-board RAM facilities to be 
shared by the on-board CPU and by another bus 
master via the Multibus. The following paragraphs 
describe the RAM Control and the overall operation 
of how the RAM is addressed for read/write opera- 
tion. 


the RAM input pins and RAS/ is driven low at the 
beginning of the first memory clock cycle. High- 
order address bits A7-A13 are presented at the RAM 
input pins and CAS/ is driven low during the second 
memory clock cycle. 

The RAM Controller also examines its RD/ and 
WRT/ inputs. If WR/ is low, the RAM Controller 
drives its WE/ output low just before CAS/, then 
high to provide a WRITE signal to RAM. 

When the memory cycle begins, the RAM Controller 
drives its SACK/ output low (delayed until XACK/ 
if refresh in progress), and when the cycle is complete 
(i.e., data is valid), drives its XACK/ output low. 
The SACK/ and XACK/ outputs go high when the 
RD/ or WRT/ input goes high. 


4-40. ON-BOARD READ/WRITE OPERA- 
TION. The 8085A CPU initiates a RAM operation 
by generating a read command (AMR/) or a write 
command (MW/). These commands are qualified by 
the Dual Port Control logic (Sheet 3) and fed to the 
inputs of the 8202 RAM Controller as DRRD/ 
(Dynamic RAM Read) and DRWR/ (Dynamic RAM 
Write). The RAM Controller chip is selected by 
DRCS/ (3ZC1) which says that the command was for 
the RAM (CSMO/) and we are not in battery backup 
operation (MEMORY PROTECT/ false). 

During a RAM read, the address from the 8085A 
(PABO-PABF) is gated into the RAM Address Buf- 
fers A63 and A64 (4ZD6) by MBEN/. The output of 
the buffers (RAD0/-RADF/) is applied to the ad- 
dress inputs of the 8202 RAM Controller, where it is 
multiplexed to the RAM. DRRD/ being true causes 
the 8202 to perform a read. The data from the RAM 
chips is latched by A78 (5ZC3) and transferred to the 
8085A CPU data bus by MBEN/ from the Dual Port 
Control logic. The RAM acknowledge (RMACK/) is 
generated by SACK/ from the 8202 qualified by the 
Dual Port Control logic. RMACK/ drives the 8085 A 
CPU’s READY line. 


4-39. RAM CONTROLLER. All address and con- 
trol inputs to the on-board RAM are supplied by 
RAM Controller A62 (5ZD6). The 8202 RAM Con- 
troller provides a RAS refresh timing cycle to 
dynamic RAM chips A79-A86. Default jumper 68-67 
holds the TREF (RAM Refresh) signal low, allowing 
the RAM Controller to operate in the automatic 
refresh mode. In the automatic refresh mode, a read 
or write request can be delayed if a refresh cycle is in 
progress. 

The RAM Controller when enabled with a low input 
to the PCS/pin, multiplexes the address to the RAM 
chips. Low order address bits A0-A6 are presented at 


During a RAM write, the data from the 8085A CPU 
is gated through A66 (5ZD2) to the RAM chips. With 
DRWR/ true on the input of the RAM Controller, 
the 8202 gates out WE/, a write operation is per- 
formed and data is written in to the location specified 
by the RAM address (R AD0/-R ADF/) . 

Reference paragraph 4-18 to determine the possible 
influence of wait states on the RAM read or write 
operations. 


4-41. BUS MASTER READ/WRITE OPERA- 
TION. Another bus master on the system can access 
the iSBC 544’s RAM. In order to do this, the bus 
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master must gain control of the RAM through the 
Dual Port Control logic, as explained in paragraph 
4-31. 

Assuming no on-board CPU access of RAM is in 
progress, address bits ADR10/-ADR13/ from the 
Multibus are decoded by A56 (4ZA6) to select a 64K 
page of memory. If bits ADR10/-ADR13/ are selec- 
ting the 64K page allocated to this board, the correct 
output of A56 will be jumpered to the input of func- 
tion BSAD/ (Board Address). Bits ADRC/-ADRF/ 
from the Multibus are compared to the Base Address 
switches (4ZB6) by Decode PROM A41 to determine 
if the address is within the 4K boundary established 
as the base address for this board. If the comparison 
is true, and if the address is within the RAM size 
(determined by positions 6 and 7 of SI), the other in- 
put to BSAD/ will be satisfied and the bus master ac- 
cess will be allowed. 

Address bits ADRO/-ADRB/ and ATRC/-ATRE/ 
are gated through the Bi-Directional Bus Drivers 
A73-A75 (5Z-7) by SBEN/ (System Bus Enable). 
When DRWR/ (Dynamic RAM Write) or DRRD/ 
(Dynamic RAM READ) becomes true on the inputs 
to the RAM Controller (5ZD6), the address in RAM 
is either read or written. The data is transferred into 
or out of the RAM (depending on read or write) 
through the Bi-Directional Bus Drivers A76 and All 
and onto or off of the Multibus (5ZC2). 

The RAM Controller generates XACK/ which is 
transferred out on the Multibus, to acknowledge ex- 
ecution of the bus masters command. 

There is one area that needs further explanation. 
Decode PROM A41 (4ZB5) is used for address com- 
parison, and also for address transformation. The 
PROM has been programmed to transform any in- 
coming address to an address starting at 8(XX)H. The 
on- board base address of RAM is 8000, so regardless 
of the base address on the Multibus and the switches, 
the address seen by the RAM must be equal to or 
greater than 8000. Appendix C shows the outputs of 
the Decode PROM for different address inputs from 
the Multibus. This transformation is necessary so 
that the Flag Interrupt logic can generate an interrupt 
unique to the iSBC 544. 


4-42. INTERRUPT OPERATION 

The following paragraphs describe the interrupt logic 
areas of the iSBC 544 Intelligent Communications 
controller. 


4-43. MULTIBUS INTERRUPTS. The on-board 
8085A can be interrupted by a bus master by way of 
the Multibus. One of eight interrupts INT0/-INT7/ 
(2ZA7) can be jumpered to the RST 5.5 input on the 
CPU. 

The 8085A can generate an interrupt request to 
another bus master. The SOD output of the 8085 A 
CPU is jumpered to one of the eight Multibus inter- 
rupt linesTNT0/-INT7/ (2ZA7). 


4-44. FLAG INTERRUPT. The Flag Interrupt is 
used as a communication device between the bus 
masters and iSBC 544 on the system. The Flag Inter- 
rupt flop A30 (5ZB2) is set when a write (DRWR/) is 
performed by a bus master into the base address of 
the on-board RAM. The output of the Flag Interrupt 
flop (FINT/) feeds to the RST 5.5 input of the CPU 
(2ZC8). The FINT output of the flop feeds to the C 
port of the 8155 PPI (6ZC8) where it can be read. 

The Flag Interrupt flop is cleared when a read 
(DRRD/) is performed on the base location of the 
RAM by the on-board 8085 A CPU. 


4-45. CARRIER DETECT INTERRUPT. The 
Carrier Detect Interrupt flops A23 and A24 (6ZC5) 
monitor the carrier detect signals on the serial ports. 
If one of the carriers (CD0-CD3) drops out, one of 
the four flops would set. When the flop sets, the 
negation side of the flop goes low setting PINT (Car- 
rier Detect Interrupt). PINT drives the RST 6.5 input 
to the CPU. The Carrier Detect signals also feed to 
port B on the 8155 PPI (6ZC7) where they can be in- 
terrogated. 


4-46. RING INDICATOR INTERRUPT. The 
Ring Indicator Interrupt flop A44 (6ZB5) monitors 
ring lines (RI0-RI3) from the serial ports. If a ring oc- 
curs on one of the lines, flop A44 sets and sets RINT 
(Ring Interrupt). RINT drives the RST 6.5 input to 
the CPU. The ring lines RI0-RI3 (6ZC8) also feed to 
port B on the 8155 PPI where they can be inter- 
rogated. 


4-47. 8259 INTERRUPT CONTROLLER. The 

8259 PIC A29 (7ZA7) monitors the interrupt lines 
from the 8251 A US ARTS. The output of the 8259 
drives the INTR line on the 8085 A CPU. 
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Figure 4-1 . iSBC 544 Input/Output and Interrupt Block Diagram 
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Figure 4-2. iSBC 544 Memory Block Diagram 
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CHAPTER 5 
SERVICE INFORMATION 


5-1. INTRODUCTION 

This chapter provides a list of replaceable parts, ser- 
vice diagrams, and service and repair assistance in- 
structions for the iSBC 544 Intelligent Communica- 
tions Controller Board. 


5-2. REPLACEABLE PARTS 

Table 5-1 provides a list of replaceable parts for the 
iSBC 544. Table 5-2 identifies and locates the 
manufacturers specified in MFR CODE column in 
table 5-1. Intel parts that are available on the open 
market are listed in the MFR CODE column as 
“COML”; every effort should be made to procure 
these parts from a local (commerical) distributor. 

5-3. SERVICE DIAGRAMS 

The iSBC 544 parts location diagram and schematic 
diagram are provided in figures 5-1 and 5-2, respec- 
tively. On the schematic diagram, a signal mnemonic 
that ends with a slash (e.g., lOWC/) is active low. 
Conversely, a signal mnemonic without a slash (e.g., 
IOC) is active high. 

5-4. SERVICE AND REPAIR 
ASSISTANCE 

United States customers can obtain service and repair 
assistance from Intel by contacting the MCD 
Technical Support Center in Santa Clara, California 
at one of the following numbers: 

Telephone: 

From Alaska or Hawaii call - 
(408) 987-8080 


From locations within California call toll free - 
(800) 672-3507 

From all other U.S. locations call toll free - 
(800) 538-8014 

TWX: 910-338-0026 

TELEX: 34-6372 

Always contact the MCD Technical Support Center 
before returning a product to Intel for service or 
repair. You will be given a “Repair Authorization 
Number”, shipping instructions, and other impor- 
tant information which will help Intel provide you 
with fast, efficient service. If the product is being 
returned because of damage sustained during ship- 
ment from Intel, or if the product is out of warranty, 
a purchase order is necessary in order for the MCD 
Technical Support Center to initiate the repair. 


In preparing the product for shipment to the MCD 
Technical Support Center, use the original factory 
packaging material, if available. If the original 
packaging is not available, wrap the product in a 
cushioning material such as Air Cap TH-240 (or 
equivalent) manufactured by the Sealed Air Corpora- 
tion, Hawthorne, N.J., and enclose in a heavy-duty 
corrugated shipping carton. Seal the carton securely, 
mark it “FRAGILE” to ensure careful handling, and 
ship it to the address specified by MCD Technical 
Support Center personnel. 


NOTE 

Customers outside of the United States 
should contact their sales source (Intel Sales 
Office or Authorized Intel Distributor) for 
directions on obtaining service or repair 
assistance. 


Table 5-1 . Replaceable Parts 


Reference 

Designation 

Description 

MFR. 

Part No. 

MFR. 

Code 

QTY. 

A1-A5, A11, A12, A16 

IC, 1489A Quad Line Receiver 

SN75189AN 

Tl 

8 

A6-A10, A14 

1C, 1488 Quad Line Driver 

SN75188AN 

Tl 

6 

A13 

IC, 74LS20 Dual 4 Input Positive-Nand Gate 

SN74LS20N 

Tl 

1 

A15 

IC, 8224 Clock Generator 

Intel 8224 

Intel 

1 

A17 

IC, 7492A Divide-By-Twelve Counter 

SN7492AN 

Tl 

1 

A18-A21 

IC, 8251 A Serial I/O Interface 

Intel 8251 A 

Intel 


A22 

IC, 8155 Programmable Peripheral Interface 

Intel 8155 

Intel 


A23, A24, A43 

IC, 74LS74 Dual D-Type Positive Trigger Flip-Flop 

SN74LS74N 

Tl 


A25, A38 

IC, 74S00 Quad 2-Input Pos. NAND-Gate 

SN74S00N 

Tl 
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Table 5-1 . Replaceable Parts (Cont’d.) 


Reference 

Designation 

Description 

MFR. 

Part No. 

MFR. 

Code 

A26, A36, A37 

IC, 74S74 Dual D-Type Flip-Flop 

SN74S74N 

Tl 

A27, A28 

IC, 8253 Programmable Interval Timer 

Intel 8253 

Intel 

A29 

IC, 8259 Programmable Interrupt Ctrir. 

Intel 8259 

Intel 

A30 

IC, 7470 Gated J-K Flip-Flop 

SN7470N 

Tl 

A31, A59 

IC, 74LS04 Hex-Inverter 

SN74LS04N 

Tl 

A32, A33, A56 

IC, 82051-of-8 Binary Decoder 

Intel 8205 

Intel 

A34 

IC, 8085A 8-Blt Microprocessor 

Intel 8085A 

Intel 

A35, A50, A51 

Socket, 24 Pin DIP 


Tl 

A39 

IC, 74LS00 Quad 2-Input Positive NAND-Gate 

SN74LS00N 

Tl 

A40 

IC, 74S32 Quad 2-lnput OR-Gate 

SN74S32N 

Tl 

A41 

IC, 3625-2 IK X 4 PROM 

9100124 

Intel 

A42, A48, A70 

IC, 74LS32 Quad 2-lnput OR-Gate 

SN74LS32N 

Tl 

A44 

IC, 74LS109 Dual J-K Flip-Flop 

SN74LS109N 

Tl 

A45 

IC, 74S175Quad D-Type Flip-Flop 

SN74S175N 

Tl 

A46 

IC, 74LS157 Data Selector/Multiplexer 

SN74LS157N 

Tl 

A47, A57 

IC, 74LS08 Quad 2-lnput Positve-AND Gates 

SN74LS08N 

Tl 

A49, A54 

IC, 74S04 Hex Inverter 

SN74S04N 

Tl 

A50 

IC, 3628 8K Bipolar PROM 

9100195 

Intel 

A52 

Not Used 



A53 

IC, 74S11 3-Input PosItive-AND Gates 

SN74S11N 

Tl 

A55 

IC, 74S20 Dual 4-Input Positive-NAND Gates 

SN74S20N 

Tl 

A58 

IC, 74S02 Quad 2-lnput Positive-NOR Gates 

SN74S02N 

Tl 

A60, A71 

IC, DM 8097 Tri-State Buffer 

DM 8097 

NAT 

A61 

IC, 74S1 33 13-Input Positive-NAND Gates 

SN74S133N 

Tl 

A62 

IC, 8202 RAM Controller 

Intel 8202 

Intel 

A63, A64 

IC, 74LS240 Octal Buffers Line Driver/Receiver 

SN74LS240N 

Tl 

A65, A78 

1C, 74LS373 Octal D-Type Latches 

SN74LS373N 

Tl 

A66, A67, A75 

IC, DP 8304 Bi-Directional Transmitter/ Receiver 

DP 8304 

NAT 

A68 

Not Used 



A69 

Not Used 



A70 

IC, 7432 Quad 2-lnput OR-Gate 

SN 7432N 

Tl 

A72 

IC, 7406 Hex Inverters Buffer/ Drivers 

SN7406N 

Tl 

A73, A74 

IC, 8216 Bi-Directional Bus Driver 

Intel 8216 

Intel 

A76, A77 

IC, Intel 8226 Bi-Directional Bus Driver 

Intel 8226 

Intel 

A79-A86 

IC, Intel 2117-4 16K RAM 

Intel 2117-4 

Intel 

CR1 

Diode, IN4002 

OBD 

COML 

C1, C4, C6-8, CIO-12, 

Capacitor, fxd., VF, +80, -20%, 50v 

QBD 

COML 

Cl 4-1 6, Cl 8-21, 26, 27, 




33-60 , 62-70 , 72-80 , 87, 




89, 95, 97, 99, 101 




C2 

Capacitor, Mica, lOpF, ±5%, 500v 

QBD 

COML 

C3 

Capacitor, fxd., 10j/F, ±10%, 20v 

OBD 

COML 

C22, C23-25, C28-31, 

Capacitor, fxd., OI^F, +80, -20%, 50v 

OBD 

COML 

C88, C96 




Cl 00, Cl 02 




C61 

Capacitor, fxd., .001 jiF, ±20%, 50v 

OBD 

COML 

C81, 86, 90, 94, 98, 103 

Capacitor, fxd., .33fiF, +80, -20%, 50v 

OBD 

COML 

C71, 82-85, 91,93 

Capacitor, fxd., 22piF, ±10%, 15v 

OBD 

COML 

C92 

Capacitor, fxd., AJ^F, ±10%, lOv 

OBD 

COML 

R1 

Resistor, fxd., comp., 100K ohm, ±5%, %w 

OBD 

COML 

R2, R8 

Resistor, fxd., comp., 5.1 K ohm, ±%, V4W 

OBD 

COML 

R3 

Resistor, fxd., comp., 10K ohm, ±5%, V4W 

OBD 

COML 

R4, R6, R7, R9 

Resistor, fxd., comp., IK ohm, ±%, V4W 

OBD 

COML 

R5 

Resistor, fxd., comp., 430 ohm, ±5%, V4W 

OBD 

COML 

RP1,RP3 

Resistor, pack, 8-pin IK ohm 

OBD 

COML 

RP2, RP4, RP6 

Resistor, pack, 8-pin 10K ohm 

OBD 

COML 

RP5, RP7 

Resistor, pack, 8-pin 22K ohm 

OBD 

COML 

SI 

Switch 8 position, DIP 

OBD 

COML 

VR1 

IC, LM320LZ-5, Voltage Regulator 

LM320LZ-5 

NAT, MOT 

Y1 

Crystal, 22.1184 MHz fundamental 

HW3 

CTS 
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Table 5-1 . Replaceable Parts (Cont’d.) 


Reference 

Designation 

Description 

MFR. 

Part No. 

MFR. 

Code 

QTY. 

W1-W4, A41 

Socket, DIP, 18-pin 

C93-18-02 


5 

A86 

Socket, DIP, 16-pin 

C93-16-02 


1 

W5-W8 

Socket, DIP, 8-pin 

C93-8-02 



A78 

Socket, DIP, 20-pin 

C93-20-02 



A62, A34 

Socket, DIP, 40-pin 

C93-40-02 


^9 


Extractor, Card 

S-203 




Pins, Wirewrap 

OBD 


75 


Table 5-2. List of Manufacturers’ Codes 


MFR. Code 

Manufacturer 

Address 

MFR. Code 

Manufacturer 

Address 

INTEL 

Intel Corporation 

Santa Clara, CA 

AMP 

AMP, Incorporated 

Harrisburg, PA 

Tl 

Texas Instruments 

Dallas, TX 

SCA 

Scanbe, Incorporated 

El Monte, CA 

CTS 

CTS Corporation 

Elkhart, IN 

COML 

Any Commercial Source; 

Order by Description 

NAT 

National Semiconductor 
Corporation 

Santa Clara, CA 

MOT 

Motorola Inc. 

Pheonix, Ariz. 
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Figure 5-1 . iSBC 544 Parts Location Diagram 
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APPENDIX A 
8085A INSTRUCTION SET 


A computer, no matter how sophisticated, can only 
do what it is “told” to do. One “tells” the computer what 
to do via a series of coded instructions referred to as a Pro- 
gram. The realm of the programmer is referred to as Soft- 
ware, in contrast to the Hardware that comprises the actual 
computer equipment. A computer’s software refers to all of 
the programs that have been written for that computer. 

When a computer is designed, the engineers provide 
the Central Processing Unit (CPU) with the ability to per- 
form a particular set of operations. The CPU is designed 
such that a specific operation is performed when the CPU 
control logic decodes a particular instruction. Consequently, 
the operations that can be performed by a CPU define the 
computer’s Instruction Set. 

Each computer instruction allows the programmer to 
initiate the performance of a specific operation. All com- 
puter’s implement certain arithmetic operations in their in- 
struction set, such as an instruction to add the contents of 
two registers. Often logical operations (e.g., OR the con- 
tents of two registers) and register operate instructions (e.g., 
increment a register) are included in the instruction set. A 
computer’s instruction set will also have instructions that 
move data between registers, between a register and memory, 
and between a register and an I/O device. Most instruction 
sets also provide Conditional Instructions. A conditional 
instruction specifies an operation to be performed only if 
certain conditions have been met; for example, jump to a 
particular instruction if the result of the last operation was 
zero. Conditional instructions provide a program with a 
decision-making capability. 

By logically organizing a sequence of instructions into 
a coherent program, the programmer can “tell” the com- 
puter to perform a very specific and useful function. 

The computer, however, can only execute programs 
whose instructions are in a binary coded form (i.e., series 
of Ts and O’s), that is called Machine Code. Because it 
would be extremely cumbersome to program in machine 
code, programming languages have been developed. There 

are programs available which convert the programming lan- 
guage instructions into machine code that can be inter- 
preted by the processor. 

One type of programming language is Assembly Lan- 
guage. A unique assembly language mnemonic is assigned to 
each of the computer’s instructions. The programmer can 
write a program (called the Source Program) using these 
mnemonics and certain operands; the source program is 
then converted into machine instructions (called the Object 
Code). Each assembly language instruction is converted into 
one machine code instruction (1 or more bytes) by an 
Assembler program. Assembly languages are usually ma- 
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chine dependent (i.e., they are usually able to run on only 
one type of computer). 

THE 8085A INSTRUCTION SET 

The 8085A instruction set includes five different types 
of instructions: 

• Data Transfer Group — move data between registers 
or between memory and registers 

• Arithmetic Group — add, subtract, increment or 
decrement data in registers or in memory 

• Logical Group — AND, OR, EXCLUSIVE-OR, com- 
pare, rotate or complement data in registers or in 
memory 

• Branch Group — conditional and unconditional 
jump instructions, subroutine call instructions and 
return instructions 

• Stack, I/O and Machine Control Group — includes 
I/O instructions, as well as instructions for main- 
taining the stack and internal control flags. 


Instruction and Data Formats: 

Memory for the 8085A is organized into 8-bit quanti- 
ties, called Bytes. Each byte has a unique 16-bit binary 
address corresponding to its sequential position in memory. 

The 8085A can directly address up to 65,536 bytes of mem- 
ory, which may consist of both read-only memory (ROM) 
elements and random-access memory (RAM) elements (read/ 
write memory). 

Data in the 8085A is stored in the form of 8-bit binary 
integers: 

DATA WORD 

D7 ' D6 ’ D5 ' D4 * D3 ' D2 * D1 * DO 
MSB LSB 

When a register or data word contains a binary num- 
ber, it is necessary to establish the order in which the bits 
of the number are written. In the Intel 8085A, BIT 0 is re- 
ferred to as the Least Significant Bit (LSB), and BIT 1 (of 
an 8 bit number) is referred to as the Most Significant Bit 
(MSB). 

The 8085A program instructions may be one, two or 
three bytes in length. Multiple byte instructions must be 
stored in successive memory locations; the address of the 
first byte is always used as the address of the instructions. 
The exact instruction format will depend on the particular 
operation to be executed. 
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8085A Instruction Set 


Single Byte Instructions 


Byte One 
Byte Two 

Byte One 
Byte Two 



~1 1 1 1 1 

'do 

Two-Byte Instructions 

D7 

1 1 1 1 1 

DO 


D7 

1 1 1 1 1 

DO 

Three-Byte Instructions 

D7 

^ 1 1 1 1 

' DO 


D7 

1 1 1 1 1 

DO 


D7 

1 1 1 1 \ 

DO 


Op Code 

Op Code 

Data or 
Address 

Op Data 

bata 

/Or 

Address 


Addressing Modes: 

Often the data that is to be operated on is stored in 
memory. When multi-byte numeric data is used, the data, 
like instructions, is stored in successive memory locations, 
with the least significant byte first, followed by increasingly 
significant bytes. The 8085A has four different modes for 
addressing data stored in memory or in registers; 

• Direct — Bytes 2 and 3 of the instruction contain 

the exact memory address of the data 
item (the low-order bits of the address are 
in byte 2, the high-order bits in byte 3). 

• Register — The instruction specifies the register or 

register-pair in which the data is located. 

• Register Indirect — The instruction specifies a reg- 

ister-pair which contains the memory 

address where the data is located (the 
high-order bits of the address are in the 
first register and the pair, the low-order 
bits in the second). 

• Immediate — The instruction contains the data it- 

self. This is either an 8-bit quantity or a 
16-bit quantity (least significant byte first, 
most significant byte second). 

Unless directed by an interrupt or branch instruction, 
the execution of instructions proceeds through consecu- 
tively increasing memory locations. A branch instruction 
can specify the address of the next instruction to be exe- 
cuted in one of two ways: 

• Direct — The branch instruction contains the ad- 

dress of the next instruction to be exe- 
cuted. (Except for the ‘RST’ instruction, 
byte 2 contains the low-order address and 
byte 3 the high-order address.) 

• Register Indirect — The branch instruction indi- 

cates a register-pair which contains the 
address of the next instruction to be exe- 
cuted. (The high-order bits of the address 
are in the first register of the pair, the 
low-order bits in the second.) 


The RST instruction is a special one-byte call instruc- 
tion (usually used during interrupt sequences). RST in- 
cludes a three-bit field; program control is transferred to 
the instruction whose address is eight times the contents 
of the three-bit field. 

Condition Flags: 

There are five condition flags associated with the exe- 
cution of instructions on the 8085A. They are Zero, Sign, 
Parity, Carry, and Auxiliary Carry, and are each represented 
by a 1-bit register in the CPU. A flag is “set” by forcing the 
bit to 1; “reset” by forcing the bit to 0. 

Zero: If the result of an instruction has the 

value 0, this flag is set; otherwise, it is 
reset. 

Sign: If the most significant bit of the result of 

the operation has the value 1, this flag is 
set; otherwise it is reset. 

Parity; If the module 2 sum of the bits of the re- 
sult of the operation is 0, (i.e., if the re- 
sult has even parity), this flag is set; 
otherwise it is reset (i.e., if the result has 
odd parity). 

Carry: If the instruction resulted in a carry (from 

addition), or a borrow (from subtraction 
or a comparison) out of the high-order 
bit, this flag is set; otherwise it is reset. 

Auxiliary Carry: If the instruction caused a carry out 
of bit 3 and into bit 4 of the resulting 
value, the auxiliary carry is set; otherwise 
it is reset. This flag is affected by single 
precision additions, subtractions, incre- 
ments, decrements, comparisons, and log- 
ical operations, but is principally used 
with additions and increments preceding 
a DAA (Decimal Adjust Accumulator) in- 
struction. 


Symbols and Abbreviations: 

The following symbols and abbreviations are used in 
the subsequent description of the 8085A instructions; 

SYMBOLS MEANING 


accumulator 
addr 
data 
data 16 
byte 2 
byte 3 
port 
r,r1,r2 
DDD.SSS 


Register A 

16-bit address quantity 

8-bit data quantity 

16-bit data quantity 

The second byte of the instruction 

The third byte of the instruction 

8-bit address of an I/O device 

One of the registers A,B,C,D,E,H,L 

The bit pattern designating one of the regis- 
ters A, B,C,D,E,H,L (DDD-destination,SSS= 
source): 
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8085A Instruction Set 


rp 


RP 


rh 

rl 

PC 


SP 


r 


m 


Z,S.P,CY,AC 


( ) 


A 

V 

V 

+ 


DDD or SSS REGISTER NAME 


111 A 

000 B 

001 C 

010 D 

011 E 

100 H 

101 L 


One of the register pairs: 

B represents the B.C pair with B as the high- 
order register and C as the low-order 
register. 

D represents the D.E pair with D as the high- 
order register and E as the low-order 
register. 

H represents the H,L pair with H as the high- 
order register and L as the low-order 
register; 

SP represents the 16-bit stack pointer 
register. 

The bit pattern designating one of the regis- 
ter pairs B,D,H,SP: 


RP 

REGISTER NAME 

00 

B-C 

01 

D-E 

10 

H-L 

11 

SP 


The first (high-order) register of a design- 
ated register pair. 

The second (low-order) register of a desig- 
nated register pair. 

16-bit program counter register (PCH and 
PCL are used to refer to the high-order and 
low-order 8 bits respectively). 

16-bit stack pointer register (SPH and SPL 
are used to refer to the high-order and low- 
order 8 bits respectively). 

Bit m of the register r (bits are number 7 
through 0 from left to right). 


The condition flags; 


Zero, 

Sign, 

Parity, 

Carry, 

and Auxiliary Carry respectively. 

The contents of the memory location of reg- 
isters enclosed in the parentheses. 

“Is transferred to” 

Logical AND 
Exclusive OR 
Inclusive OR 


Addition 
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Two’s complement subtraction 
Multiplication 
“Is exchanged with” 

The one’s complement (e.g., (A)) 

The restart number 0 through 7 

The binary representation 000 through 111 
for restart number 0 through 7 respectively. 

Description Format: 

The following pages provide a detailed description of 
the instruction set of the 8085A. Each instruction is de- 
scribed in the following manner; 

1 . The MCS OS^^macro assembler format, consisting of 
the instruction mnemonic and operand fields, is 
printed in BOLDFACE on the left side of the first 
line. 

2. The name of the instruction is enclosed in paren- 
thesis on the right side of the first line. 

3. The next iine(s) contain a symbolic description 
of the operation of the instruction. 

4. This is followed by a narative description of the 
operation of the instruction. 

5. The following line(s) contain the binary fields and 
patterns that comprise the machine instruction. 

6. The last four lines contain incidental information 
about the execution of the instruction. The num- 
ber of machine cycles and states required to exe- 
cute the instruction are listed first. If the instruc- 
tion has two possible execution times, as in a 
Conditional Jump, both times will be listed, sep- 
arated by a slash. Next, any significant data ad- 
dressing modes (see Page A-2) are listed. The last 
line lists any of the five Flags that are affected by 
the execution of the instruction. 



Data Transfer Group: 

This group of instructions transfers data to and from 
registers and memory. Condition flags are not affected by 
any instruction in this group. 


MOV rl, r2 (Move Register) 

(rl) (r2) 

The content of register r2 is moved to register rl. 


Cycles; 1 
States: 4 

Addressing: register 
Flags; none 
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MOV r, M (Move from memory) 

(r) ((H) (D) 

The content of the memory location, whose address 
is in register H and L, is moved to register r. 




D ' 


D ’ 


1 ’ 



Cycles 

States 

Addressing 

Flags 


2 

7 

reg. indirect 
none 


MOV M, r (Move to memory) 

((H) (L))-^(r) 

The content of register r is moved to the memory lo- 
cation whose address is in registers H and L. 




1 

, ' 

0 





Cycles 

States 

Addressing 

Flags 


2 

7 

reg. indirect 
none 


MVI r, data (Move Immediate) 

(r) -mr— (byte 2) 

The content of byte 2 of the instruction is moved to 
register r. 


O O D D D1 10 


data 


LXI rp, data 16 (Load register pair immediate) 

(rh) ^ — (byte 3), 

(rl) (byte 2) 

Byte 3 of the instruction is moved into the high-order 
register (rh) of the register pair rp. Byte 2 of the in- 
struction is moved into the low-order register (rl) of 
the register pair rp. 



Cycles: 

States; 

Addressing: 

Flags; 


3 

10 

immediate 

none 


LDA addr (Load Accumulator direct) 

(A) ((byte 3) (byte 2)) 

The content of the memory location, whose address 
is specified in byte 2 and byte 3 of the instruction, is 
moved to register A. 



Cycles: 4 
States: 13 
Addressing: direct 
Flags: none 


Cycles; 

States; 

Addressing: 

Flags; 


2 

7 

immediate 

none 


MVI M, data (Move to memory immediate) 

((H) (D) (byte 2) 

The cont.ent of byte 2 of the instruction is moved to 
the memory location whose address is in registers H 
and L. 


0 0 1 1 0 110 


data 


Cycles: 

States: 

Addressing; 

Flags; 


3 

10 

immed./reg. indirect 
none 


STA addr (Store Accumulator direct) 

((byte 3) (byte 2)) -^(A) 

The content of the accumulator is moved to the 
memory location whose address is specified in byte 
2 and byte 3 of the instruction. 



Cycles: 4 
States; 1 3 
Addressing: direct 
Flags; none 
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LHLD addr (Load H and L direct) 

(L) ((byte 3) (byte 2)) 

(H)-^((byte 3) (byte 2) + 1) 

The content of the memory location, whose address 
is specified in byte 2 and byte 3 of the instruction, is 
moved to register L. The content of the memory loca- 
tion at the succeeding address is moved to register H. 



Cycles: 5 
States; 1 6 
Addressing; direct 
Flags; none 


SHLD addr (Store H and L direct) 

((byte 3) (byte 2)) (L) 

((byte 3) (byte 2) + 1) -•—(H) 

The content of register L is moved to the memory lo- 
cation whose address is specified in byte 2 and byte 
3. The content of register H is moved to the succeed- 
ing memory location. 



Cycles: 5 
States; 16 
Addressing: direct 
Flags; none 


STAX rp (Store Accumulator indirect) 

((rp)) (A) 

The content of register A is moved to the memory lo- 
cation whose address is in the register pair rp. Note: 
Only register pairs rp=B (registers B and C) or rp=D 
(registers D and E) may be specified. 


0 


R 







Cycles 

States 

Addressing 

Flags 


2 

7 

reg. indirect 
none 


XCHG (Exchange H and L with D and E) 

(H)-«-(D) 

(L)-^(E) 

The contents of registers H and L are exchanged with 
the contents of registers D and E. 


1 


1 




1 



Cycles; 1 
States: 4 

Addressing; register 
Flags; none 


Arithmetic Group: 

This group of instructions performs arithmetic oper- 
ations on data in registers and memory. 

Unless indicated otherwise, all instructions in this 
group affect the Zero, Sign, Parity, Carry, and Auxiliary 
Carry flags according to the standard rules. 

All subtraction operations are performed via two’s 
complement arithmetic and set the carry flag to one to in- 
dicate a borrow and clear it to indicate no borrow. 


LDAX rp (Load Accumulator indirect) 

(A) ^ ((rp)) 

The content of the memory location, whose address ADD r (Add register) 

is in the register pair rp, is moved to register A. Note; (A) — ■ — (A) + (r) 

Only register pairs rp=B (registers B and C) or rp=D The content of register r is added to the content of the 

(registers D and E) may be specified. accumulator. The result is placed in the accumulator. 


Cycles: 

2 

Cycles; 

1 

States; 

7 

States: 

4 

Addressing: 

reg. indirect 

Addressing; 

register 

Flags; 

none 

Flags; 

Z,S,P,CY,AC 
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ADD M (Add memory) 

(A)-^ (A) + ((H) (D) 

The content of the memory location whose address 
is contained in the H and L registers is added to the 
content of the accumulator. The result is placed in 
the accumulator. 


ACI data (Add immediate with carry) 

(A) (A) + (byte 2) + (CY) 

The content of the second byte of the instruction and 
the content of the CY flag are added to the contents 
of the accumulator. The result is placed in the 
accumulator. 



Cycles: 2 
States: 7 

Addressing: reg. indirect 
Flags: Z.S.P.CY.AC 



Cycles: 2 
States: 7 

Addressing: immediate 
Flags: Z.S.P.CY.AC 


ADI data (Add immediate) 

(A) (A) + (byte 2) 

The content of the second byte of the instruction is 
added to the content of the accumulator. The result 
is placed in the accumulator. 



data 


Cycles: 2 
States: 7 

Addressing: immediate 
Flags: Z.S.P.CY.AC 


ADC r (Add Register with carry) 

(A) (A) + (r) + (CY) 

The content of register r and the content of the carry 
bit are added to the content of the accumulator. The 
result is placed in the accumulator. 



Cycles: 1 
States: 4 

Addressing: register 

Flags: Z.S.P.CY.AC 


SUB r (Subtract Register) 

(A) (A) - (r) 

The content of register r is subtracted from the con- 
tent of the accumulator. The result is placed in the 
accumulator. 



Cycles: 1 
States: 4 

Addressing: register 

Flags. Z.S.P,CY.AC 


ADC M (Add memory with carry) 

(A)^ (A) + ((H) (L)) MCY) 

The content of the memory location whose address is 
contained in the H and L registers and the contents of 
the CY flag are added to the accumulator. The result 
is placed in the accumulator. 


SUB M (Subtract memory) 

(A) ^iH-(A) - ((H) (D) 

The content of the memory location whose address is 
contained in the H and L registers is subtracted from 
the content of the accumulator. The result is placed 
in the accumulator. 



Cycles: 2 
States: 7 

Addressing: reg. indirect 

Flags: Z.S.P.CY.AC 


Cycles: 2 
States: 7 

Addressing: reg. indirect 
Flags: Z.S.P.CY.AC 
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SUI data (Subtract immediate) 

(A)-« — (A) - (byte 2) 

The content of the second byte of the instruction is 
subtracted from the content of the accumulator. The 
result is placed in the accumulator. 



Cycles; 2 
States; 7 

Addressing; immediate 
Flags; Z,S,P,CY,AC 


SBI data (Subtract immediate with borrow) 

(A)^ (A) - (byte 2) - (CY) 

The contents of the second byte of the instruction 
and the contents of the CY flag are both subtracted 
from the accumulator. The result is placed in the 
accumulator. 



Cycles; 2 
States; 7 

Addressing; immediate 
Flags; Z,S.P,CY,AC 


SBB r (Subtract Register with borrow) 

{A)-^(A) - (r) - (CY) 

The content of register r and the content of CY 
flag are both subtracted from the accumulator. The 
result is placed in the accumulator. 



Cycles; 1 
States; 4 

Addressing; register 

Flags; Z.S.P.CY.AC 


INR r (Increment Register) 

(r) (r) + 1 

The content of register r is incremented by one. 
Note; All condition flags except CY are affected. 



Cycles; 1 
States; 4 

Addressing; register 
Flags; Z.S.P.AC 


INR M (Increment memory) 

((H) (L))-«— ((H) (D) +1 

The content of the memory location whose address 
is contained in the H and L registers is incremented 
by one. Note; All condition flags except CY are 
affected. 



Cycles; 3 
States; 1 0 

Addressing; reg. indirect 
Flags; Z,S,P,AC 


SBB M (Subtract memory with borrow) 

(A)-«- (A)-t(H) (L))-(CY) 

The content of the memory location whose address is 
contained in the H and L registers and the content of 
the CY flag are both subtracted from the accumula- 
tor. The result is placed in the accumulator. 



Cycles; 2 
States; 7 

Addressing; reg. indirect 
Flags; Z,S,P,CY,AC 
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OCR r (Decrement Register) 

(r) (r) - 1 

The content of register r is decremented by one. 
Note; All condition flags except CY are affected. 



Cycles; 1 
States; 4 

Addressing; register 
Flags; Z,S,P,AC 
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DCR M (Decrement memory) 

((H) (L))-^((H) (D) -1 

The content of the memory location whose address is 
contained in the H and L registers is decremented by 
one. Note: All condition flags except CY are affected. 


Cycles: 

States: 

Addressing: 

Flags: 


3 

10 

reg. indirect 
Z,S,P,AC 


INX rp (Increment register pair) 

(rh) (rl)^ (rh) (rl) + 1 

The contents of the register pair rp is incremented by 
one. Note: No condition fiags are affected. 


Cycles: 1 

States: 6 

Addressing: register 

Flags: none 


DAA (Decimal Adjust Accumulator) 

The eight-bit number in the accumulator is adjusted 
to form two four-bit Binary-Coded-Decimal digits by 
the following process: 

1. If the value of the least significant 4 bits of the 
accumulator is greater than 9 or if the AC flag is 
set, 6 is added to the accumulator. 

2. If the value of the most significant 4 bits of the 
accumulator is now greater than 9, or if the CY flag 
is set, 6 is added to the most significant 4 bits of 
the accumulator. 


NOTE: All flags are affected. 


0 


1 ' 0 

' 0 ' 1 ' 1 

' 1 



Cycles: 

1 




States: 

4 




Flags: 

Z,S,P,CY,AC 



Logical Group: 

This group of instructions performs logical (Boolean) 
operations on data in registers and memory and on condi- 
tion flags. 

Unless indicated otherwise, all instructions in this 
group affect the Zero, Sign, Parity, Auxiliary Carry, and 
Carry flags according to the standard rules. 


DCX rp (Decrement register pair) 

(rh) (rl)-*- (rh) (rl) - 1 

The content of the register pair rp is decremented by 
one. Note: No condition flags are affected. 











ANA r (AND Register) 

(A) (A) A (r) 

The content of register r is logically anded with the 
content of the accumulator. The result is placed in 
the accumulator. The CY flag is cleared and AC is set. 


1 1 


1 



' s 




Cycles: 

1 

Cycles: 

1 

States: 

6 

States: 

4 

Addressing: 

register 

Addressing: 

register 

Flags: 

none 

Flags: 

Z,S,P,CY,AC 


DAD rp (Add register pair to H and L) 

(H) (L) -^(H) (L) + (rh) (rl) 

The content of the register pair rp is added to the 
content of the register pair H and L. The result is 
placed in the register pair H and L. Note: Only the 
CY flag is affected. It is set if there is a carry out of 
the double precision add; otherwise it is reset. 


ANA M (AND memory) 

(A)-*— (A) A ((H) (L)) 

The contents of the memory location whose address 
is contained in the H and L registers is logically anded 
with the content of the accumulator. The result is 
placed in the accumulator. The CY flag is cleared and 
AC is set. 



Cycles: 3 
States: 10 

Addressing: register 

Flags: CY 


Cycles 

States 

Addressing 

Flags 


2 

7 

reg. indirect 
Z,S,P,CY,AC 


All Mnemonics Copyrighted « mtel Corporation i976, 1977 

A-8 








8085A Instruction Set 


ANI data (AND immediate) 

(A)-^ (A) A (byte 2) 

The content of the second byte of the instruction is 
logically anded with the contents of the accumulator. 
The result is placed in the accumulator. The CY flag 
is cleared and AC is set. 



XRI data (Exclusive OR immediate) 

(A)-*— (A) V (byte 2) 

The content of the second byte of the instruction is 
exclusive-OR’d with the content of the accumulator. 
The result is placed in the accumulator. The CY and 

AC flags are cleared. 



Cycles: 2 
States; 7 

Addressing: immediate 

Flags: Z,S,P,CY,AC 


Cycles: 2 
States: 7 

Addressing: immediate 
Flags: Z,S,P,CY,AC 


XRA r (Exclusive OR Register) ORA r (OR Register) 

(A) (A) V(r) (A) (A) V (r) 

The content of register r is exclusive-or’d with the The content of register r is inclusive-OR’d with the 

content of the accumulator. The result is placed in content of the accumulator. The result is placed in 

the accumulator. TheCY andAC flags are cleared. the accumulator. The CY and AC flags are cleared. 



Cycles: 1 
States: 4 

Addressing; register 

Flags: Z.S.P.CY.AC 


Cycles; 1 
States: 4 

Addressing; register 

Flags: Z,S,P,CY,AC 


XRA M (Exclusive OR memory) 

(A)-^(A)V((H) (L)) 

The content of the memory location whose address 
is contained in the H and L registers is exclusive-OR’d 
with the content of the accumulator. The result is 
placed in the accumulator. The CY and AC flags are 
cleared. 



Cycles: 2 
States: 7 

Addressing: reg. indirect 

Flags: Z,S,P,CY,AC 
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ORA M (OR memory) 

(A)-ie- (A) V((H) (L)) 

The content of the memory location whose address is 
contained in the H and L registers is inclusive-OR’d 
with the content of the accumulator. The result is 
placed in the accumulator. The CY and AC flags are 
cleared. 



Cycles: 2 
States; 7 

Addressing; reg. indirect 
Flags: Z,S,P,CY,AC 
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ORI data (OR immediate) 

(A)-^(A) V(byte 2) 

The content of the second byte of the instruction is 
inclusive-OR’d with the content of the accumulator. 
The result is placed in the accumulator. The CY and 

AC flags are cleared. 


data 


Cycles: 

States: 

Addressing: 

Flags: 


2 

7 

immediate 

Z,S,P,CY,AC 


CPI data (Compare immediate) 

(A) - (byte 2) 

The content of the second byte of the instruction is 
subtracted from the accumulator. The condition flags 
are set by the result of the subtraction. The Z flag is 
set to 1 if (A) = (byte 2). The CY flag is set to 1 if 
(A)<{byte 2). 


data 


Cycles: 

States: 

Addressing: 

Flags: 


2 

7 

immediate 

Z,S.P,CY.AC 


CMP r (Compare Register) 

(A) - (r) 

The content of register r is subtracted from the ac- 
cumulator. The accumulator remains unchanged. The 
condition flags are set as a result of the subtraction. 

The Z flag is set to 1 if (A) = (r). The CY fiag is set to 
1 if(A)<(r). 


1 ' 



' 1 



S ’ 

' ^ 1 


Cycles: 

States: 

Addressing: 

Flags: 


1 

4 

register 

Z,S,P,CY,AC 


RLC (Rotate left) 

(An+1) — (An); (Aq) (Ay) 

(CY)-e— (Ay) 

The content of the accumulator is rotated left one 
position. The low-order bit and the CY flag are both 
set to the value shifted out of the high-order bit posi- 
tion. Only the CY flag is affected. 



0 ' 



1 ' 





Cycles: 

1 






States: 

4 






Flags: 

CY 





CMP M (Compare memory) 

(A) - ((H) (D) 

The content of the memory location whose address 
is contained in the H and L registers is subtracted 
from the accumulator. The accumulator remains un- 
changed. The condition flags are set as a result of the 
subtraction. The Z flag Is set to 1 It (A) = ((H) (L)). 
The CY flag is set to 1 if (A)<((H) (L)). 


1 ^ ' 


1 ' 



' 1 ' 

1 ' 

' 0 


Cycles: 2 
States: 7 

Addressing: reg. indirect 

Flags: Z.S.P.CY.AC 


RRC (Rotate right) 

(An) (An-l): (A7 ) (Aq) 

(CY)-*- (Aq) 

The content of the accumulator is rotated right one 
position. The high-order bit and the CY flag are both 
set to the value shifted out of the low-order bit posi- 
tion. Only the CY flag is affected. 


■7^ 


0 ' 0 



1 

, 



Cycles: 

1 






States: 

4 






Flags: 

CY 
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RAL (Rotate left through carry) 

(An+l)-^ (An); (CY)-^ (Ay) 

(Ao)-^(CY) 

The content of the accumulator is rotated left one 
position through the CY flag. The low-order bit is set 
equal to the CY flag and the CY flag is set to the 
value shifted out of the high-order bit. Only the CY 
flag is affected. 


Cycles: 1 
States: 4 
Flags: CY 


CMC (Complement carry) 

(CY)-*- (CY) 

The CY flag is complemented. No other flags are 
affected. 


0 

0 ' 

1 ' , 


1 

1 




Cycles: 

1 






States: 

4 






Flags: 

CY 





RAR (Rotate right through carry) 

(An) (An+1): (CY) (Aq) 

(At) (CY) 

The content of the accumulator is rotated right one 
position through the CY flag. The high-order bit is set 
to the CY flag and the CY flag is set to the value 
shifted out of the low-order bit. Only the CY flag is 
affected. 



T 

0 

0 ' 1 







Cycles: 

1 






States: 

4 






Flags: 

CY 





CMA (Complement accumulator) 

(A)-«— (A) 

The contents of the accumulator are complemented 
(zero bits become 1, one bits become 0). No flags are 
affected. 


0 1 


1 ' 


1 1 

1 

1 1 I 


1 


Cycles: 1 
States: 4 

Flags: none 
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STC (Set carry) 

(CY)-^ 1 

The CY flag is set to 1. No other flags are affected. 


0 

0 ' 

1 ' , 



rT“ 




Cycles: 

1 






States: 

4 






Flags: 

CY 





Branch Group: 

This group of instructions alter normal sequential 
program flow. 

Condition flags are not affected by any instruction 
in this group. 

The two types of branch instructions are uncondi- 
tional and conditional. Unconditional transfers simply per- 
form the specified operation on register PC (the program 
counter). Conditional transfers examine the status of one of 
the four processor flags to determine if the specified branch 
is to be executed. The conditions that may be specified are 
as follows: 


CONDITION CCC 

NZ — not zero (Z = 0) 000 

Z — zero (Z = 1) 001 

NC — no carry (CY = 0) 010 

C — carry (CY = 1) 011 

PC — parity odd (P = 0) 100 

PE — parity even (P = 1) 101 

P — plus (S = 0) 110 

M — minus (S = 1) 111 
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JMP addr (Jump) 

(PC)-« — (byte 3) (byte 2) 

Control is transferred to the instruction whose ad- 
dress is specified in byte 3 and byte 2 of the current 
instruction. 


r--| „ I , I , 


low-order addr 


high-order addr 


Cycles: 

States: 

Addressing: 

Flags: 


3 

10 

immediate 

none 


0 ' 1 


low-order addr 


high-order addr 


Cycles 

States 

Addressing 

Flags 


5 

18 

immediate/reg. indirect 
none 


Jcondition addr (Conditional jump) 

If (CCC), 

(PC) ^ — (byte 3) (byte 2) 

If the specified condition is true, control is trans- 
ferred to the instruction whose address is specified in 
byte 3 and byte 2 of the current instruction; other- 
wise, control continues sequentially. 



Cycles 

States 

Addressing 

Flags 


2/3 

7/10 

immediate 

none 


CALL addr (Call) 

((SP) -1)-^ (PCH) 

((SP) - 2) — ^ (PCD 
(SP)^ — (SP) -2 
(PC) ^ — (byte 3) (byte 2) 

The high-order eight bits of the next instruction ad- 
dress are moved to the memory location whose 
address is one less than the content of register SP. 
The low-order eight bits of the next instruction ad- 
dress are moved to the memory location whose 
address is two less than the content of register SP. 
The content of register SP is decremented by 2. Con- 
trol is transferred to the instruction whose address is 
specified in byte 3 and byte 2 of the current in- 
struction. 

* All Mnemonics Copyrighted » Intel Corporation 1976, 1977 
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Ccondition addr (Condition call) 

If (CC), 

((SP) -1)-^ (PCH) 

((SP) -2)-^(PCL) 

(SP) (SP) - 2 
(PC) — « — (byte 3) (byte 2) 

If the specified condition is true, the actions specified 
in the CALL instruction (see above) are performed; 
otherwise, control continues sequentially. 


low-order addr 


high-order addr 


Cycles 

States 

Addressing 

Flags 


2/5 

9/18 


immediate/reg. indirect 
none 


RET (Return) 

(PCL)-^((SP)); 

(PCH)-« — ((SP) + 1); 

(SP) — (SP) + 2; 

The content of the memory location whose address 
is specified in register SP is moved to the low-order 
eight bits of register PC. The content of the memory 
location whose address is one more than the content 
of register SP is moved to the high-order eight bits of 
register PC. The content of register SP is incremented 
by 2. 




0 

' 0 ' 

' , 





Cycles: 

States: 

Addressing: 

Flags: 


3 

10 

reg. indirect 
none 
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Rcondition (Conditional return) 

If (CCC), 

(PCD ^ ((SP)) 

(PCH)-*- ((SP) + 1) 

(SP) (SP) + 2 

If the specified condition is true, the actions specified 
in the RET instructions (see above) are performed; 
otherwise, control continues sequentially. 



Cycles 

States 

Addressing 

Flags 


1/3 

6/12 

reg. indirect 
none 


1 ' i ' 0 ' 0 ' 0 ^ 


Cycles: 1 
States: 6 

Addressing: register 

Flags: none 


Stack, I/O, and Machine Control Group: 

This group of instructions performs I/O, manipulates 
the Stack, and alters internal control flags. 

Unless otherwise specified, condition flags are not 
affected by any instructions in this group. 


RST n (Restart) 

((SP) -1)— (PCH) 

((SP) -2)-^ (PCD 
(SP)-« — (SP) -2 
(PC )^ — 8 * (NNN) 

The high-order eight bits of the next instruction ad- 
dress are moved to the memory location whose 
address is one less than the content of register SP. 
The low-order eight bits of the next instruction ad- 
dress are moved to the memory location whose 
address is two less than the content of register SP. 
The content of register SP is decremented by two. 
Control is transferred to the instruction whose ad- 
dress is eight times the content of NNN. 


1 1 



DT 

DT 





Cycles 

States 

Addressing 

Flags 


3 

12 

reg. indirect 
none 


PUSH rp (Push) 

((SP) -i)^ (rh) 

((SP) - 2) (rl) 

(SP) (SP) - 2 

The content of the high-order register of register pair 
rp is moved to the memory location whose address is 
one less than the content of register SP. The content 
of the low-order register of register pair rp is moved 
to the memory location whose address is two less 
than the content of register SP. The content of reg- 
ister SP is decremented by 2. Note: Register pair 
rp = SP may not be specified. 


1 



P 

0 



1 


Cycles 

States 

Addressing 

Flags 


3 

12 

reg. indirect 
none 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

N 

N 

N 

0 

0 

0 


Program Counter After Restart 


PCHL (Jump H and L indirect — move H and L to PC) 
(PCH)-^(H) 

(PCD-^(D 

The content of register H is moved to the high-order 
eight bits of register PC. The content of register L is 
moved to the low-order eight bits of register PC. 
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PUSH PSW (Push processor status word) 

((SP) -1)-^ (A) 

((SP) -2)0-« — (CY), ((SP) -2)1-*— X 
((SP) - 2)2 (P), ((SP) - 2)3 -*r- X 

((SP) - 2)4 (AC), ((SP) - 2)5 -•—X 

((SP) - 2)6 — — (Z), ((SP) -2)7-^(S) 

(SP) -* — (SP) - 2 X: Undefined. 

The content of register A is moved to the memory 
location whose address is one less than register SP. 
The contents of the condition flags are assembled 
into a processor status word and the word is moved 
to the memory location whose address is two less 
than the content of register SP. The content of reg- 
ister SP is decremented by two. 
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1 

1 

, 


0 


0 




Cycles: 

States; 

Addressing; 

Flags; 

3 

12 

reg. indirect 

none 






FLAG WORD 




D7 

D6 

D5 

D4 

D3 

D2 

D1 

DO 

S 

Z 

X 

AC 

X 

P 

X 

CY 


X: undefined 


XTHL (Exchange stack top with H and L) 

(L)-*-^({SP)) 

(H)-m-((SP) + 1) 

The content of the L register is exchanged with the 
content of the memory location whose address is 
specified by the content of register SP The content 
of the H register is exchanged with the content of the 
memory location whose address is one more than the 
content of register SP. 


1 1 



’ 0 






Cycles: 

5 






States; 

16 





Addressing: reg. indirect 

Flags: none 


POP rp (Pop) 

(rl) ((SP)) 

(rh)^ ((SP) + 1) 

(SP) (SP) + 2 

The content of the memory location, whose address 
is specified by the content of register SP, is moved to 
the low-order register of register pair rp. The content 
of the memory location, whose address is one more 
than the content of register SP, is moved to the high- 
order register of register pair rp. The content of reg- 
ister SP is incremented by 2. Note: Register pair 
rp = SP may not be specified. 




' R ' 


' 0 ' 


' 0 ' 

1 1 


Cycles 

States 

Addressing 

Flags 


3 

10 

reg. indirect 
none 


POP PSW (Pop processor status word) 

(CY)-.- ((SP))0 
(P) ((SP))2 

(AC)-^ ((SP))4 
(Z)— — ((SP))6 
(S) ((SP))7 

(AP)-^ ((SP) + 1) 

(SP) (SP) + 2 

The content of the memory location whose address 
is specified by the content of register SP is used to 
restore the condition flags. The content of the mem- 
ory location whose address is one more than the 
content of register SP is moved to register A. The 
content of register SP is incremented by 2. 




' , ' 


' 0 


' 0 ' 

1 


SPHL (Move HL to SP) 

(SP)— (H) (L) 

The contents of registers H and L (16 bits) are moved 
to register SP. 


1 1 



1 

1 



nr 

nn 


Cycles; 1 
States: 6 

Addressing; register 
Flags: none 


IN port (Input) 

(A)-« — (data) 

The data placed on the eight bit bi-directional data 
bus by the specified port is moved to register A. 


1 ' 1 ' 0 I 1 ' 1 ' 0 ' 1 ' 1 

port 


Cycles: 3 
States: 10 

Addressing: direct 
Flags: none 


OUT port (Output) 

(data)-^— (A) 

The content of register A is placed on the eight bit 
bi-directional data bus for transmission to the spec- 
ified port. 


port 


Cycles; 

3 

Cycles: 

3 

States; 

10 

States: 

10 

Addressing: reg. indirect 


Addressing; 

direct 

Flags: 

Z,S,P,CY,AC 

Flags: 

none 
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El (Enable interrupts) 

The interrupt system is enabled following the execu- 
tion of the next instmction. 


1 

, 

' 1 ' , 

' 1 r 0 





Cycles: 

1 





States: 

4 





Flags: 

none 




(Disable interrupts) 

The interrupt system is disabled immediately fol 
lowing the execution of the Di instruction. 

1 I , ' 1 ' 1 

' 1 

1 

1 

Cycles: 

1 


States: 

4 


Flags: 

none 



OPCODE: 


ACCUMULATOR 
CONTENT 
AFTER RIM: 


CYCLES: 1 
STATES: 4 
FLAGS: NONE 


7 0 

I 0 I Q h I 0 I 0 I 0 I 0 I Q 1 



SIM (Set Interrupt- Masks) 

During execution of the SIM instruction, the con- 
tents of the accumulator will be used in program- 
ming the restart interrupt masks. Bits 0-2 will set/ 
reset the mask bit for RST 5.5, 6.5, 7.5 of the interrupt 
mask register, if bit 3 is 1 (“set”). Bit 3 is a “Mask Set 
Enable” control. 

Setting the mask (i.e., masked bit = 1) disables the 
corresponding interrupt. 


HLT (Halt) 

The processor is stopped. The registers and flags are 
unaffected. 




, ' 

' 1 

' 0 I 





Cycles; 1 
States: 5 
Flags: none 


NOP (No op) 

No operation is performed. The registers and flags 
are unaffected. 



Cycles: 1 
States: 4 
Flags: none 


RIM (Read Interrupt Mask) 

After the execution of the RIM instruction, the 
accumulator is loaded with the restart interrupt 
masks, any pending interrupts, and the contents of 
the serial input data line (SID). 



Set 

Reset 

RST 5.5 MASK 

RST 6.5 MASK 

RST 7.5 MASK 

if bit 0 = 1 

bit 1 = 1 

bit 2 = 1 

if bit 0 = 0 

bit 1 = 0 

bit 2 = 0 


RST 7.5 (edge trigger enable) internal request flip 
flop will be reset if bit 4 of the accumulator = 1; regard- 
less of whether RST 7.5 is masked or not. 


RESET IN input (pin 36) will set all RST MASKs, and 
reset/disable all interrupts. 

SIM can, also load the SOD output latch. Accumu- 
lator bit 7 is loaded into the SOD latch if bit 6 is set. 
The latch is unaffected if bit 6 is a zero. RESET IN 
input sets the SOD latch to zero. 


OPCODE 



ACCUMULATOR 


0 


CONTENT 
FOR SIM: 


SOD SOE X R7.5 MSE M7.5 M6.5 M5.5 


I! 


RST 5.5 MASK 
RST 6.5 MASK 
RST 7.5 MASK 
MASK SET ENABLE 
RESET RST 7.5 
UNDEFINED 
SOD ENABLE 
SERIAL OUTPUT DATA 


CYCLES: 1 
STATES: 4 
FLAGS: NONE 
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INSTRUCTION SET 

Summary of Processor Instructions 


Mnemonic 

Description 

D7 

D6 

Instruction Code [1] 
D5 D4 D3 D2 

D1 

DO 

Clock[2] 

Cycles 

Mnemonic 

Description 

D7 

D6 

Instruction Code [1] 
i D5 04 D3 D2 

Dl 

DO 

Clock [2] 
Cycles 

MOV r1, r2 

Move register to register 

0 

1 

D 

D 

D 

S 

s 

s 

5 

RZ 

Return on zero 

1 

1 

0 

0 

1 

0 

0 

0 

5/11 

MOV M, r 

Move register to memory 

0 

1 

1 

1 

0 

S 

s 

s 

7 

RNZ 

Return on no zero 

1 

1 

0 

0 

0 

0 

0 

0 

5/11 

MOV r, M 

Move memory to register 

0 

1 

D 

D 

D 

1 

1 

0 

7 

RP 

Return on positive 

1 

1 

1 

1 

0 

0 

0 

0 

5/11 

HLT 

Halt 

0 

1 

1 

1 

0 

1 

1 

0 

T 

RM 

Return on minus 

1 

1 

1 

1 

1 

0 

0 

0 

5/11 

MVI r 

Move immediate register 

0 

0 

D 

D 

D 

1 

1 

0 

7 

RPE 

Return on parity even 

1 

1 

1 

0 

1 

0 

0 

0 

5/11 

MVI M 

Move immediate memory 

0 

0 

1 

1 

0 

1 

1 

0 

10 

RPO 

Return on parity odd 

1 

1 

1 

0 

0 

0 

0 

0 

5/11 

INR r 

Increment register 

0 

0 

D 

D 

D 

1 

0 

0 

5 

RST 

Restart 

1 

1 

A 

A 

A 

1 

1 

1 

11 

DOR r 

Decrement register 

0 

0 

D 

D 

D 

1 

0 

1 

5 

IN 

Input 

1 

1 

0 

1 

1 

0 

1 

1 

10 

INR M 

Increment memory 

0 

0 

1 

1 

0 

1 

0 

0 

10 

OUT 

Output 

1 

1 

0 

1 

0 

0 

1 

1 

10 

DOR M 

Decrement memory 

0 

0 

1 

1 

0 

1 

0 

1 

10 

LXI B 

Load immediate register 

0 

0 

0 

0 

0 

0 

0 

1 

10 

ADD r 

Add register to A 

1 

0 

0 

0 

0 

s 

s 

s 

4 


Pair B & C 










ADC r 

Add register to A with carry 

1 

0 

0 

0 

1 

s 

s 

s 

4 

LXI D 

Load immediate register 

0 

0 

0 

1 

0 

0 

0 

1 

10 

SUB r 

Subtract register from A 


0 

0 

1 

0 

s 

s 

s 

4 


Pair D & E 










SBB r 

Subtract register from A 

1 

0 

0 

1 

1 

s 

s 

s 

4 

LXI H 

Load immediate register 

0 

0 

1 

0 

0 

0 

0 

1 

10 


with borrow 











Pair H & L 










ANA r 

And register with A 

1 

0 

1 

0 

0 

s 

s 

s 

4 

LXI SP 

Load immediate stack pointer 

0 

0 

1 

1 

0 

0 

0 

1 

10 

XRA r 

Exclusive Or register with A 

1 

0 

1 

0 

1 

s 

s 

s 

4 

PUSH B 

Push register Pair B & C on 

1 

1 

0 

0 

0 

1 

0 

1 

11 

ORA r 

Or register with A 

1 

0 

1 

1 

0 

s 

s 

s 

4 


stack 










CMPr 

Compare register with A 

1 

0 

1 

1 

1 

s 

s 

s 

4 

PUSH D 

Push register Pair D & E on 

1 

1 

0 

1 

0 

1 

0 

1 

11 

ADD m 

Add memory to A 

1 

0 

0 

0 

0 

1 

1 

0 

7 


stack 










ADC M 

Add memory to A with carry 

1 

0 

0 

0 

1 

1 

1 

0 

7 

PUSH H 

Push register Pair H & L on 

1 

1 

1 

0 

0 

1 

0 

1 

11 

SUB M 

Subtract memory from A 

1 

0 

0 

1 

0 

1 

1 

0 

7 


stack 










SBB M 

Subtract memory from A 

1 

0 

0 

1 

1 

1 

1 

0 

7 

PUSH PSW 

Push A and Flags 

1 

1 

1 

1 

0 

1 

0 

1 

11 


with borrow 











on stack 










ANA M 

And memory with A 

1 

0 

1 

0 

0 

1 

1 

0 

7 

POP B 

Pop register pair B & C off 

1 

1 

0 

0 

0 

0 

0 

1 

10 

XRA M 

Exclusive Or memory with A 

1 

0 

1 

0 

1 

1 

1 

0 

7 


stack 










ORA M 

Or memory with A 

1 

0 

1 

1 

0 

1 

1 

0 

7 

POP D 

Pop register pair D & E off 

1 

1 

0 

1 

0 

0 

0 

1 

10 

CMP M 

Compare memory with A 

1 

0 

1 

1 

1 

1 

1 

0 

7 


stack 










ADI 

Add immediate to A 

1 

1 

0 

0 

0 

1 

1 

0 

7 

POP H 

Pop register pair H & L off 

1 

1 

1 

0 

0 

0 

0 

1 

10 

ACI 

Add immediate to A with 

1 

1 

0 

0 

1 

1 

1 

0 

7 


slack 











carry 










POP PSW 

Pop A and Flags off stack 

1 

1 

1 

1 

0 

0 

0 

1 

10 

SUI 

Subtract immediate from A 

1 

1 

0 

1 

0 

1 

1 

0 

7 

STA 

Store A direct 

0 

0 

1 

1 

0 

0 

1 

0 

13 

SBI 

Subtract immediate from A 

1 

1 

0 

1 

1 

1 

1 

0 

7 

LDA 

Load A direct 

0 

0 

1 

1 

1 

0 

1 

0 

13 


with borrow 










XCHG 

Exchange D & E, H & L 

1 

1 

1 

0 

1 

0 

1 

1 

4 

ANI 

And immediate with A 

1 

1 

1 

0 

0 

1 

1 

0 

7 


Registers 










XRI 

Exclusive Or immediate 

1 

1 

1 

0 

1 

1 

1 

0 

7 

XTHL 

Exchange top of slack, H S L 

1 

1 

1 

0 

0 

0 

1 

1 

18 


with A 










SPHL 

H & L to stack pointer 

1 

1 

1 

1 

1 

0 

0 

1 

5 

ORI 

Or immediate with A 

1 

1 

1 

1 

0 

1 

1 

0 

7 

PCHL 

H & L to program counter 

1 

1 

1 

0 

1 

0 

0 

1 

5 

CPI 

Compare immediate with A 

1 

1 

1 

1 

1 

1 

1 

0 

7 

DAD B 

Add B & C to H & L 

0 

0 

0 

0 

1 

0 

0 

1 

10 

RLC 

Rotate A left 

0 

0 

0 

0 

0 

1 

1 

1 

4 

DAD D 

Add D & E to H & L 

0 

0 

0 

1 

1 

0 

0 

1 

10 

RRC 

Rotate A right 

0 

0 

0 

0 

1 

1 

1 

1 

4 

DADH 

Add H & L to H & L 

0 

0 

1 

0 

1 

0 

0 

1 

10 

RAL 

Rotate A left through carry 

0 

0 

0 

1 

0 

1 

1 

1 

4 

DAD SP 

Add stack pointer to H & L 

0 

0 

1 

1 

1 

0 

0 

1 

10 

RAR 

Rotate A right through 

0 

0 

0 

1 

1 

1 

1 

1 

4 

STAX B 

Store A indirect 

0 

0 

0 

0 

0 

0 

1 

0 

7 


carry 










STAX D 

Store A indirect 

0 

0 

0 

1 

0 

0 

1 

0 

7 

JMP 

Jump unconditional 

1 

1 

0 

0 

0 

0 

1 

1 

10 

LDAX B 

Load A indirect 

0 

0 

0 

0 

1 

0 

1 

0 

7 

JC 

Jump on carry 

1 

1 

0 

1 

1 

0 

1 

0 

10 

LDAX D 

Load A indirect 

0 

0 

0 

1 

1 

0 

1 

0 

7 

JNC 

Jump on no carry 

1 

1 

0 

1 

0 

0 

1 

0 

10 

INX B 

Increment B & C registers 

0 

0 

0 

0 

0 

0 

1 

1 

5 

JZ 

Jump on zero 

1 

1 

0 

0 

1 

0 

1 

0 

10 

INX D 

Increment D & E registers 

0 

0 

0 

1 

0 

0 

1 

1 

5 

JNZ 

Jump on no zero 

1 

1 

0 

0 

0 

0 

1 

0 

10 

INX H 

Increment H & L registers 

0 

0 

1 

0 

0 

0 

1 

1 

5 

JP 

Jump on positive 

1 

1 

1 

1 

0 

0 

1 

0 

10 

INX SP 

Increment stack pointer 

0 

0 

1 

1 

0 

0 

1 

1 

5 

JM 

Jump on Minus 

1 

1 

1 

1 

1 

0 

1 

0 

10 

OCX B 

Decrement B & C 

0 

0 

0 

0 

1 

0 

1 

1 

5 

JPE 

Jump on parity even 

1 

1 

1 

0 

1 

0 

1 

0 

10 

OCX D 

Decrement D & E 

0 

0 

0 

1 

1 

0 

1 

1. 

5 

JPO 

Jump on parity odd 

1 

1 

1 

0 

0 

0 

1 

0 

10 

OCX H 

Decrement H & L 

0 

0 

1 

0 

1 

0 

1 

1 

5 

CALL 

Call unconditional 

1 

1 

0 

0 

1 

1 

0 

1 

17 

DCX SP 

Decrement stack pointer 

0 

0 

1 

1 

1 

0 

1 

1 

5 

CC 

Call on carry 

1 

1 

0 

1 

1 

1 

0 

0 

11/17 

CMA 

Complement A 

0 

0 

1 

0 

1 

1 

1 

1 

4 

CNC 

Call on no carry 

1 

1 

0 

1 

0 

1 

0 

0 

11/17 

STC 

Set carry 

0 

0 

1 

1 

0 

1 

1 

1 

4 

CZ 

Call on zero 

1 

1 

0 

0 

1 

1 

0 

0 

11/17 

CMC 

Complement carry 

0 

0 

1 

1 

1 

1 

1 

1 

4 

CNZ 

Call on no zero 

1 

1 

0 

0 

0 

1 

0 

0 

11/17 

DAA 

Decimal adjust A 

0 

0 

1 

0 

0 

1 

1 

1 

4 

CP 

Call on positive 

1 

1 

1 

1 

0 

1 

0 

0 

11/17 

SHLD 

Store H & L direct 

0 

0 

1 

0 

0 

0 

1 

0 

16 

CM 

Call on minus 

1 

1 

1 

1 

1 

1 

0 

0 

11/17 

LHLD 

Load H & L direct 

0 

0 

1 

0 

1 

0 

1 

0 

16 

CPE 

Call on parity even 

1 

1 

1 

0 

1 

1 

0 

0 

11/17 

El 

Enable Interrupts 

1 

1 

1 

1 

1 

0 

1 

1 

4 

CPO 

Call on parity odd 

1 

1 

1 

0 

0 

1 

0 

0 

11/17 

Dl 

Disable Interrupts 

1 

1 

1 

1 

0 

0 

1 

1 

4 

RET 

Return 

1 

1 

0 

0 

1 

0 

0 

1 

10 

NOP 

No-operation 

0 

0 

0 

0 

0 

0 

0 

0 

4 

RC 

Return on carry 

1 

1 

0 

1 

1 

0 

0 

0 

5/11 

RIM 

Read Interrupt Mask 

0 

0 

1 

0 

0 

0 

0 

0 

4 

RNC 

Return on no carry 

1 

1 

0 

1 

0 

0 

0 

0 

5/11 

SIM 

Set Interrupt Mask 

0 

0 

1 

1 

0 

0 

0 

0 

4 


NOTES; 1. ODD or SSS — OOOB — 001 C — 010 D — 01 1 E — 100 H — 101 L — 110 Memory — 111 A. 
2. Two possible cycle times, (5/11) indicate instruction cycles dependent on condition flags. 
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APPENDIX B 
TELETYPEWRITER MODIFICATIONS 


B-1. INTRODUCTION 

This appendix provides information required to modify a 
Model ASR-33 Teletypewriter for use with certain Intel 
SBC 80 computer systems. 

B-2. INTERNAL MODIFICATIONS 

/warning/ 

Hazardous voltages are exposed when the top 
cover of the teletypewriter is removed. To pre- 
vent accidental shock, disconnect the teleprinter 
power cord before proceeding beyond this 
point. 

Remove the top cover and modify the teletypewriter as 
follows: 

a. Remove blue lead from 750-ohm tap on current 
source register; reconnect this lead to 1450-ohm tap. 
(Refer to figures B-1 and B-2.) 

b. On terminal block, change two wires as follows to 
create an internal full-duplex loop (refer to figures B-1 
and B-3): 

1. Remove brown/yellow lead from terminal 3; re- 
connect this lead to terminal 5. 

2. Rfemove white/blue lead from terminal 4; recon- 
nect this lead to terminal 5. 

c. On terminal block, remove violet lead from terminal 
8; reconnect this lead to terminal 9. This changes the 
receiver current level from 60 mA to 20 mA. 

A relay circuit card must be fabricated and connected to 
the paper tape reader drive circuit. The relay circuit card 
to be fabricated requires a relay, a diode, a thyractor, a 
small ‘vector’ board for mounting the components, and 
suitable hardware for mounting the assembled relay card. 

A circuit diagram of the relay circuit card is included in 
figure B-4; this diagram also includes the part numbers 
of the relay, diode, and thyractor. (Note that a 470-ohm 
resistor and a 0.1 /rF capacitor may be substituted for 
the thyractor.) After the relay circuit card has been 


assembled, mount it in position as shown in figure B-5. 
Secure the card to the base plate using two self-tapping 
screws. Connect the relay circuit to the distributor trip 
magnet and mode switch as follows: 


a. Refer to figure B'-4 and connect a wire (Wire ‘A’) 
from relay circuit card to terminal L2 on mode 
switch. (See figure B-6.) 

b. Disconnect brown wire shown in figure B-7 from 
plastic connector. Connect this brown wire to termi- 
nal L2 on mode switch. (Brown wire will have to be 
extended.) 

c. Refer to figure B-4 and connect a wire (Wire ‘B’) 
from relay circuit board to terminal LI on mode 
switch. 

B-3. EXTERNAL CONNECTIONS 

Connect a two-wire receive loop, a two-wire send loop, 
and a two-wire tape reader control loop to the external 
device as shown in figure B-4. The external connector pin 
numbers shown in figure B-4 are for interface with an 
RS232C device. 


B-4. SBC 530 TTY ADAPTER 

The SBC 530, which converts RS232C signal levels to an 
optically isolated 20 mA current loop interface, pro- 
vides signal translation for transmitted data, received 
data, and a paper tape reader relay. The SBC 530 inter- 
faces an Intel SBC 80 computer system to a teletype- 
writer as shown in figure B-8. 

The SBC 530 requires +12V at 98 mA and -12V at 98 
mA. An auxiliary supply must be used if the SBC 80 
system does not supply this power. A schematic diagram 
of the SBC 530 is supplied with the unit. The following 
auxiliary power connector (or equivalent) must be pro- 
cured by the user: 

Connector, Molex 09-50-7071 
Pins, Molex 08-50-0106 
Polarizing Key, Molex 15-04-0219 
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Teletypewriter Modifications 



Figure B-1. Teletype Component Layout 



Figure B-2. Current Source Resistor Figure B-3. Terminal Block 
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Teletypewriter Modifications 






FOR CIRCUiT CARD 


LOCAl 


RELAYS 


MOUNT iMG screw! 


Figure B-5. Relay Circuit 


Figure B-6. Mode Switch 
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Teletypewriter Modifications 



Figure B-7. Distributor Trip Magnet 



Figure B-8. TTY Adapter Cabling 








APPENDIX C 
CUSTOM PROGRAMMED PROMS 


C-1. INTRODUCTION 

This appendix provides information about two 
custom programmed PROMS used on the iSBC 544. 
One is used for on-board Chip Select and Address 
Selection (A50), and the other is used for Address 
Transformation (A41)and off-board Address Selec- 
tion. The components can be referenced on figure 
5-2, Sheet 4 while reading this information. 

C-2. CHIP SELECT PROM 

The SBC-544 has two blocks of RAM, up to 2 
EPROMS, and 8 Peripheral Chips. These functional 
blocks inter-connect with several on-board buses. It 
is the job of this PROM to select the proper block, 
send control signals to the Bus Enable logic, and 
generate an acknowledge if required. 

There are several versions of this PROM which are 
used to configure the SBC-544 in various forms. 
These PROMS differ only in the size of and location 
of the I/O, RAM, and EPROM blocks. 

This version is for 16K RAM and 4K or 8K of 
EPROM. 

The PROM used is an Intel 3628, IK by 8 Bipolar 
PROM. As such, it has 10 address inputs and 8 out- 
puts. Eight of the inputs (PROM address lines AO 
thru A7) connect to the upper 8 CPU address lines so 
that the PROM may select the proper chips. PROM 
address input A9 is the lO/M signal from the 8085A 
to tell the PROM if the current access is to memory 
or lO. Input A8 is connected to an option switch (SI 
section 7) which allows the user to select 1 of 2 possi- 
ble sizes for the EPROM block. 


There are 15 chip select lines required. These outputs 
are encoded on the lower 4 bits of the output (01, 02, 
03, & 04). This encoded output is decoded by 2 l-of-8 
decoders connected as a l-of-16 decoder. Table C-1 
shows the relation of encoded chip select output and 
the function enable. Output 08 is used to indicate 
that the current access is to on-board I/O or 
memory. This signal is active-low. Output of 07 in- 
dicates that the current access is an access to on- 
board I/O or EPROM (active-low). This output is 
used to generate an acknowledge to the CPU. Output 
06 indicates that the current access should take place 
over the I/O data bus (also active-low). Output 05 is 
not used. Table C-2 shows the relation of input ad- 
dresses to outputs. For all addresses not shown, the 
outputs are inactive (all ones). 


Table C-1 . Chip Select Coding 


CS Output 

Function Enabled 

0 

EPROM 0 

1 

EPROM 1 

2 

Reserved 

3 

Reserved 

4 

USARTO) 

5 

USART 1 I 3251 AS 

6 

USART2( 

7 

USARTsj 

8 

} 8253 PITs 

9 

TIMER 1 j 

A 

Parallel Port/Static RAM | 8155 PPI 

B 

Set Master Mode 

C 

Reset Master Model 

D 

Interrupt Control 1 8259 PIC 

E 

Dynamic RAM 

F 

None 


Table C-2. Chip Select Addressing 


Address 

lO/M 

CS Outputs 

10 Bus 

10 Ack 

OnBd 

0000-07FF 

M 

00 

X 

X 

X 

0800-OFFF 

M 

1 

X 

X 

X 

7F00-7FFF 

M 

A 

- 

X 

X 

8000-8FFF 

M 

E 



X 

DO 


4 

X 

X 

X 

D1 


4 

X 

X 

X 

D2 


5 

X 

X 

X 

D3 


5 

X 

X 

X 

D4 

■■ 

6 

X 

X 

X 
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Custom Programmed PROMS 


iSBC 544 


Table C-2. Chip Select Addressing (Cont’d.) 


Address 

iO/M 

CS Outputs 

10 Bus 

lOAck 

On Bd 

D5 


6 

X 

X 

X 

D6 


7 

X 

X 

X 

D7 


7 

X 

X 

X 

D8 


8 

X 

X 

X 

D9 


8 

X 

X 

X 

DA 


8 

X 

X 

X 

DB 


8 

X 

X 

X 

DC 


9 

X 

X 

X 

DD 


9 

X 

X 

X 

DE 


9 

X 

X 

X 

DF 


9 

X 

X 

X 

E4 


B 

X 

X 

X 

E5 


C 

X 

X 

X 

E6 


D 

X 

X 

X 

E7 


D 

X 

X 

X 

E8 


A 

- 

X 

X 

E9 


A 

- 

X 

X 

EA 


A 

- 

X 

X 

EB 


A 

- 

X 

X 

EC 


A 

- 

X 

X 

ED 


A 

- 

X 

X 

EE 

10 

A 

- 

X 

X 

EF 

10 

A 

- 

X 

X 


Note: Memory sizes shown are max. An “X” means the signal is active. 


Table C-4. Chip Select Decode PROM Outputs (8K of ROM) 


Page 0 A=0 IO/M=M Option Switch=On 


B = CPU 
Address 
(ADRC-F) 






C 

= CPU Address (ADR8-B) 






D 

1 

2 

3 

4 

5 

6 

7 

8 

9 

A 

ffi 

C 

D 

E 

F 

0 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

10 

1 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

11 

2 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

3 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 

FF 

FF 

FF 

FF 

4 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 

FF 

FF 

FF 

FF 

5 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 

FF 

FF 

FF 

FF 

6 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 

FF 

FF 

FF 

FF 

7 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 

FF 

FF 

FF 

3A 

8 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 


7E 

7E 

7E 

7E 

7E 

7E 

7E 

9 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 


7E 

7E 

7E 

7E 

7E 

7E 

7E 

A 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 


7E 

7E 

7E 

7E 

7E 

7E 

7E 

B 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 


7E 

7E 

7E 

7E 

7E 

7E 

7E 

C 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 

FF 

FF 

FF 

FF 

D 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 

FF 

FF 


FF 

FF 

FF 

E 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

■3J 

FF 

FF 

FF 


FF 

FF 

FF 

F 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

Ff 

FF 

FF 

FF 


FF 

FF 

FF 


For presentation here^the PROM is broken up into 4 
256-byte pages. lO/M (PROM input A9) breaks the 
PROM into 2 halves, and the option switch (PROM 
input A8) breaks each half into 2 sections. Table C-3 
shows the relation of inputs to PROM pages. 


Table C-3. PROM Page Partitioning 


lO/M 

Si-Position 

PROM Page 

M 

ON 

0 

M 

OFF 

1 

10 

ON 

2 

10 

OFF 

3 


C-3. CHIP SELECT PROM OUTPUTS 

Tables C-4 through C-6 show the possible PROM 
outputs under specified conditions. For presentation 
here, the PROM address is split into 3 bytes. The 
page number (A) specifies the upper 2 bits of address 
(A8 & A9). The left hand column of each table (B) 
specifies the middle 4 bits of address (A4, A5, A6, & 
A7). The top row of each table specifies the lower 4 
bit of address (AO, A1 , A2, & A3). 

The PROM address way be found by combining 
bytes “A”, “B”, & “C”. For example: a particular 
entry is on page 2, row 5, column 9. The address 
within the PROM is 259 hex. 
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Custom Programmed PROMS 


Table C-5 . Chip Select Decode PROM Outputs (4K of ROM) 

Pagel A=1 IO/M=M Option Switch=Off 


B = CPU 
Address 
(ADRC-F) 






C 

= CPU Address (ADR8-B) 






D 

1 

2 

3 

4 

5 

6 

7 

8 

9 

A 

B 

C 

D 

E 

F 

0 

10 

10 

10 

10 

10 

10 

10 

10 

11 

11 

11 

11 

11 

11 

11 

11 

1 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

2 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

3 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

4 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

5 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

6 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

7 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

3A 

8 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

9 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

A 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

B 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

7E 

C 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

D 

FF 

111 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

E 

FF 

lii 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

F 

FF 

m 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


Table C-6. Chip Select Decode PROM Outputs (I/O Chips) 

Page 2 or 3 A=2or3 I0/M=I/0 Option Switch=On or Off 


B = CPU 
Address 
(ADRC-F) 






C 

= CPU Address (ADR8-B) 






D 

1 

2 

3 

4 

5 

6 

7 

8 

9 

A 

B 

C 

D 

E 

11. 

0 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

1 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

2 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

3 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

4 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

5 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

6 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

7 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

8 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

9 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

A 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

B 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

C 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

D 

14 

14 

15 

15 

16 

16 

17 

17 

18 

18 

18 

18 

19 

19 

19 

19 

E 

FF 

FF 

FF 

FF 

IB 

1C 

ID 

ID 

3A 

3A 

3A 

3A 

3A 

3A 

3A 

3A 

F 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 

FF 


FF 


C-4. ADDRESS TRANSFORMATION 
PROM 


The SBC-544 has up to 16K of dual port RAM which 
may be accessed by both the on-board processor and 
the bus. The base address of RAM on-board is fixed. 
The base address of RAM from the bus may be set on 


any 4K boundry. It is the job of this PROM to 
“transform” the bus address to the proper on-board 
address for correct dual-port access. 

The base address as seen from the bus is set by 4 swit- 
ches: sections 1 thru 4 of SI. These switches may be 
set in any one of 16 patterns, corresponding to the 16 
4K boundries in a 64K address space. Table C-7 
shows how these switches are set. 


C-3 




































































Custom Programmed PROMS 
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Table C-7. RAM Base Address 


0=S witch On, l=SwitchOff 


4 

S1 

3 2 

1 

Base 

Address 

0 

0 

0 

0 

0000 H 

0 

0 

0 

1 

1000H 

0 

0 

1 

0 

2000 H 

0 

0 

1 

1 

3000 H 

0 

1 

0 

0 

4000H 

0 

1 

0 

1 

5000H 

0 

1 

1 

0 

6000H 

0 

1 

1 

1 

7000H 

1 

0 

0 

0 

8000 H 

1 

0 

0 

1 

9000H 

1 

0 

1 

0 

AOOOH 

1 

0 

1 

1 

BOOOH 

1 

1 

0 

0 

COOOH 

1 

1 

0 

1 

DOOOH 

1 

1 

1 

0 

EOOOH 

1 

1 

1 

1 

FOOOH 


the complement of the actual input. Four more ad- 
dress inputs (PROM lines A4, A5, A6, A7) connect 
to the base address switches to tell the PROM the 
desired starting point of RAM. The final two inputs 
(PROM lines A8 and A9) connect to the RAM size 
switches to determine the amount of RAM on the 
bus. 


One of the PROM outputs (04) is the RAM select 
line. This output is negative-true, that is, it goes low 
when an on-board RAM location is selected. 


The other three outputs are the transformed address 
lines to the RAM. These lines are also negative-true. 
Output 01=ATRC/, 02=ATRD/, 03=ATRE/. Note 
that since 16K is the maximum memory size, ADRF 
is not needed. 


The size of RAM available to the bus may also be 
specified. Two additional switches enable 4K, 8K, or 
16K to the bus. See table C-8. 


For explanation purposes, the PROM is broken up 
into 4 256-byte pages. Each page corresponds to one 
setting of the RAM size switches. Table C-9 shows 
the relation between switch settings and the PROM 
page selected. 


Table C-8. RAM Size 


C=SwitchOn, l=SwitchOff 


S1 

6 5 

RAM 

Size 

0 

0 

4K 

0 

1 

8K 

1 

0 

16K 

1 

1 

N/A 


RAM may also be totally disabled from the bus by 
setting the base address to FOOOH and the RAM size 
to 16K. 


The PROM used is an Intel 3625-2, IK by 4 bipolar 
PROM. As such, it has 10 address inputs and 4 out- 
puts. Four of the inputs, (PROM address lines AO, 
Al, A2, A3) connect directly to bus address lines 
ADRC/, ADRD/, ADRE/, ADRF/. These lines tell 
the PROM the current address on the bus so that the 
PROM may determine if that address is for the on- 
board RAM. Since the address lines on the bus are in- 
verted, the address represented by the inputs will be 


Table C-9. RAM Size-PROM Page 


0=SwitchOn, l=SwitchOff 


SI 

6 5 

RAM 

Size 

PROM 

Page 

PROM Address 
Range 

0 

0 

4K 

0 

OOOOH-OFFH 

0 

1 

8K 

1 

100H-1FFH 

1 

0 

16K 

2 

200H-2FFH 

1 

1 

N/A 

N/A 

N/A 


C-5. ADDRESS TRANSFORMATION 
PROM OUTPUTS 


Tables C-10 through C-12 show the contents of the 
Address Transformation PROM for different size 
RAMS. For explanation purposes, the PROM ad- 
dress is split into 3 bytes. The page number (A) 
specifies the upper 2 bits of the address (A8 & A9). 
The left hand column of each table (B) specifies the 
middle 4 bits of the address (A4, A5, A6, and A7). 
The top row of each table specifies the lower 4 bits of 
the address (AO, Al, A2, and A3). The PROM ad- 
dress may be found by combining bytes A, B, and C. 
For example: a particular entry is on page 2, row 5, 
column 9. The address within the PROM is 259 Hex. 
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Custom Programmed PROMS 


Table C-10. Address Transformation PROM Output (4K RAM) 


PageO A=0 RAM Size=4K 



Table C-1 1 . Address Transformation PROM Output (8K RAM) 


Page 1 A=1 RAM Size=8K 
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Table C-12. Address Transformation PROM Output (16K RAM) 


Page 2 A=2 RAMSize=16K 


B = Base 
Address 
Switches 






c 

= Bus Address (Inverted) 






D 

1 

2 

3 

4 

5 

6 

7 

8 

9 

A 

B 

C 

D 

E 

F 

0 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

1 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

2 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

3 

F 

F 

F 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

4 

F 

F 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

5 

F 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

F 

6 

F 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

F 


7 

F 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

F 

F 


8 

F 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

F 

F 

F 


9 

F 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

F 

F 

F 

F 


A 

F 

F 

4 

5 

6 

7 

F 

F 

F 

F 

F 

F 

F 

F 

F 


B 

F 

4 

5 

6 


F 

F 

F 

F 

F 

F 

F 

F 

F 

F 


C 

4 

5 

6 

7 


F 

F 

F 

F 

F 

F 

F 

F 

F 

F 


D 

5 

6 

7 

F 


F 

F 

F 

F 

F 

F 

F 

F 

F 

F 


E 

6 

7 

F 

F 


F 

F 

F 

F 

F 

F 

F 

F 

F 

F 


F 

F 

F 

F 

F 

u 

F 

F 

F 

F 

F 

F 

F 

F 

F 

F 

bB 
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